rxjs/Subscription не имеет подписки на экспортируемый член '
Я обновил свой угловой проект и все мои зависимости до последней версии. Без особых проблем я решил большинство проблем с зависимостями, но я все еще застрял на RxJS. Вот мой package.json:
"dependencies": {
"@angular-devkit/build-angular": "^0.6.0",
"@angular/animations": "^6.0.0",
"@angular/common": "^6.0.0",
"@angular/compiler": "^6.0.0",
"@angular/core": "^6.0.0",
"@angular/forms": "^6.0.0",
"@angular/http": "^6.0.0",
"@angular/platform-browser": "^6.0.0",
"@angular/platform-browser-dynamic": "^6.0.0",
"@angular/router": "^6.0.0",
"angular-bootstrap-md": "^6.0.1",
"core-js": "^2.5.5",
"font-awesome": "^4.7.0",
"rxjs": "^6.1.0",
"zone.js": "^0.8.26"
},
"devDependencies": {
"@angular/cli": "~6.0.0",
"@angular/compiler-cli": "^6.0.0",
"@angular/language-service": "6.0.0",
"@types/jasmine": "~2.8.3",
"@types/jasminewd2": "~2.0.3",
"@types/node": "~6.0.60",
"codelyzer": "^4.0.1",
"electron": "^1.8.3",
"jasmine-core": "~2.8.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~2.0.2",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "^1.4.2",
"karma-jasmine": "~1.1.2",
"karma-jasmine-html-reporter": "^1.0.0",
"protractor": "~5.3.1",
"ts-node": "~6.0.2",
"tslint": "~5.10.0",
"typescript": "~2.7.2"
Я импортирую только два модуля из RxJS:
import { fromPromise } from 'rxjs/observable/fromPromise';
import { Subscription } from 'rxjs/Subscription';
Они оба дают одну и ту же ошибку:
[ts] Module '"***/node_modules/rxjs/Subscription"' has no exported
member 'Subscription'.
Это точно так же для fromPromise
. Вот сообщение об ошибке, которое я получаю от Subscribtion.d.ts
(я никак не изменил код)
ОБНОВИТЬ:
Ответы ниже решили проблему с fromPromise
но fromPromise
все еще дает ту же проблему, даже если она экспортирована правильно:
export * from 'rxjs-compat/observable/fromPromise';
Ответы
Ответ 1
В RxJS 6 есть много серьезных изменений. Например, методы-прототипы, такие как
myObservable.map(data => data * 2)
больше не будет работать и должен быть заменен
myObservable.pipe(map(data => data * 2))
Все подробности можно найти здесь: https://github.com/ReactiveX/rxjs/blob/master/docs_app/content/guide/v6/migration.md
Пока вы не исправите все критические изменения, вы можете снова rxjs-compat
работать свой старый код с помощью rxjs-compat
(https://github.com/ReactiveX/rxjs/tree/master/compat).
Этот пакет необходим для обратной совместимости с RxJS до версии 6. Он содержит импорт для добавления операторов в Observable.prototype
и методы создания в Observable
.
Введите это, чтобы установить его:
npm install -s rxjs-compat
Ответ 2
Вы можете исправить это с помощью этого:
import { from } из 'rxjs';
И вместо: return Observable.fromPromise (новое обещание ((разрешить, отклонить) => {
Теперь просто сделайте:
возврат из (новое обещание ((разрешить, отклонить) => {
То же самое относится к Observable.of
Ответ 3
Я надеюсь, что ваша проблема будет решена с помощью этого заявления ниже
import Subscription from 'rxjs'
Ответ 4
afaik Angular 6 и rxjs 6 еще не совместимы, для совместимости, которую они создали https://www.npmjs.com/package/rxjs-compat, вам нужно установить
[UPDATE] fromPromise теперь "от". см. здесь: https://github.com/ReactiveX/rxjs/issues/3525
Ответ 5
Для второй части вашего вопроса, чтобы использовать fromPromise, вы можете использовать импорт 'from'. У меня была такая же проблема с rxjs 6 и изменилась на использование "from".
import { from } from 'rxjs';
from(......)