Как импортировать angular2-cookie в проект angular4

Я пытаюсь импортировать angular2-cookie в мой проект angular4.

Мой проект построен с angular-cli@1.2.7, вот мой package.json:

{
  "name": "ng-admin",
  "version": "0.0.0",
  "license": "MIT",
  "scripts": {
    "ng": "ng",
    "start": "ng serve --port 4201",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e"
  },
  "private": true,
  "dependencies": {
    "@angular/animations": "^4.0.0",
    "@angular/common": "^4.0.0",
    "@angular/compiler": "^4.0.0",
    "@angular/core": "^4.0.0",
    "@angular/forms": "^4.0.0",
    "@angular/http": "^4.0.0",
    "@angular/platform-browser": "^4.0.0",
    "@angular/platform-browser-dynamic": "^4.0.0",
    "@angular/router": "^4.0.0",
    "angular2-cookie": "^1.2.6",
    "core-js": "^2.4.1",
    "rxjs": "^5.1.0",
    "zone.js": "^0.8.4"
  },
  "devDependencies": {
    "@angular/cli": "^1.2.7",
    "@angular/compiler-cli": "^4.0.0",
    "@types/jasmine": "2.5.38",
    "@types/node": "~6.0.60",
    "codelyzer": "~2.0.0",
    "jasmine-core": "~2.5.2",
    "jasmine-spec-reporter": "~3.2.0",
    "karma": "~1.4.1",
    "karma-chrome-launcher": "~2.1.1",
    "karma-cli": "~1.0.1",
    "karma-coverage-istanbul-reporter": "^0.2.0",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "~5.1.0",
    "ts-node": "~2.0.0",
    "tslint": "~4.5.0",
    "typescript": "~2.2.0"
  }
}

angular2-cookie doc https://github.com/salemdar/angular2-cookie попросите меня добавить что-нибудь в angular-cli-build.js, но у меня нет ни angular-cli-build.js ни systemjs.config.js

Я импортирую angular2-cookie в app.module.ts с:

import { CookieService } from 'angular2-cookie/services/cookies.service';
...
...
providers: [
    CookieService
 ]

Мой проект хорошо работает с ng server и это также хорошо работает в моем хроме.

он успешно построен с ng build --prod, но когда я запускаю его в Chrome или запустить его с ng server --aot, консоль chrome показывает эту ошибку:

ERROR Error: No provider for CookieOptions! 

Как я могу решить эту проблему? Спасибо всем!

1 ответ

Решение

Добавьте CookieOptions в свой оператор импорта, например import { CookieService, CookieOptions } из 'angular2-cookie'; а затем добавьте и CookieService, и CookieOptions в массив провайдеров вашего корневого модуля.

Другие вопросы по тегам