- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我今天将我的 Angular 应用程序更新到第 9 版,它在没有 IVY 编译器的情况下运行良好。
一旦启用 Ivy,我就会收到以下错误(在应用程序启动时)并且不知道如何继续。
它似乎与更改检测器引用和管道有关,但是当我使用自定义管道时,没有人使用更改检测器。
runtime.js:26 ERROR Error: No value provided for @angular/core symbol 'ɵɵinjectPipeChangeDetectorRef'. at R3JitReflector.push../node_modules/@angular/compiler/fesm5/compiler.js.R3JitReflector.resolveExternalReference (vendor.js:36836) at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.JitEmitterVisitor.visitExternalExpr (vendor.js:36772) at ExternalExpr.push../node_modules/@angular/compiler/fesm5/compiler.js.ExternalExpr.visitExpression (vendor.js:31428) at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.AbstractEmitterVisitor.visitInvokeFunctionExpr (vendor.js:36217) at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.AbstractJsEmitterVisitor.visitInvokeFunctionExpr (vendor.js:36572) at InvokeFunctionExpr.push../node_modules/@angular/compiler/fesm5/compiler.js.InvokeFunctionExpr.visitExpression (vendor.js:31285) at vendor.js:36401 at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.AbstractEmitterVisitor.visitAllObjects (vendor.js:36420) at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.AbstractEmitterVisitor.visitAllExpressions (vendor.js:36401) at JitEmitterVisitor.push../node_modules/@angular/compiler/fesm5/compiler.js.AbstractEmitterVisitor.visitInstantiateExpr (vendor.js:36257)
{
"name": "mycompanyname",
"version": "0.0.0",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e",
"bundle-report": "webpack-bundle-analyzer dist/stats.json"
},
"private": true,
"dependencies": {
"@angular/animations": "^9.0.0",
"@angular/cdk": "^8.2.3",
"@angular/common": "^9.0.0",
"@angular/compiler": "^9.0.0",
"@angular/core": "^9.0.0",
"@angular/flex-layout": "^9.0.0-beta.29",
"@angular/forms": "^9.0.0",
"@angular/material": "^8.2.3",
"@angular/material-moment-adapter": "^8.2.3",
"@angular/platform-browser": "^9.0.0",
"@angular/platform-browser-dynamic": "^9.0.0",
"@angular/router": "^9.0.0",
"@datorama/akita": "^4.17.0",
"@datorama/akita-ng-router-store": "^4.0.0",
"@datorama/akita-ngdevtools": "^3.0.2",
"@microsoft/signalr": "^3.1.0",
"@types/applepayjs": "^3.0.0",
"@types/braintree-web": "^3.47.0",
"@types/fb": "0.0.23",
"@types/gapi": "0.0.39",
"@types/gapi.auth2": "0.0.51",
"@types/google.analytics": "0.0.40",
"@types/google.visualization": "0.0.51",
"@types/hammerjs": "^2.0.36",
"@types/highlight.js": "^9.12.3",
"@types/jwt-decode": "^2.2.1",
"@types/lodash-es": "^4.17.3",
"@types/mailcheck": "^1.1.31",
"@types/smoothscroll-polyfill": "^0.3.1",
"@types/universal-analytics": "^0.4.3",
"@types/uuid": "^3.4.6",
"@types/vkbeautify": "^0.99.2",
"@types/youtube": "0.0.38",
"braintree-web": "^3.56.0",
"core-js": "^3.5.0",
"dependency-tree": "^7.2.0",
"fast-safe-stringify": "^2.0.7",
"hammerjs": "^2.0.8",
"highlight.js": "^9.17.1",
"immer": "^5.0.1",
"intersection-observer": "^0.7.0",
"json2typescript": "^1.2.3",
"jwt-decode": "^2.2.0",
"lodash-es": "^4.17.15",
"lottie-web": "^5.5.10",
"mailcheck": "^1.1.1",
"moment": "^2.24.0",
"ng-in-viewport": "^6.0.3",
"ng2-google-charts": "^4.0.0",
"ngx-cookie": "^4.1.2",
"ngx-highlightjs": "^4.0.2",
"ngx-markdown": "^8.2.1",
"ngx-md": "^8.0.0",
"normalize.css": "^8.0.1",
"normalizr": "^3.4.1",
"pretty-data": "^0.40.0",
"rxjs": "^6.5.3",
"rxjs-etc": "^9.6.2",
"safe-json-stringify": "^1.2.0",
"slugify": "^1.3.6",
"smoothscroll-polyfill": "^0.4.4",
"svg-inline-loader": "^0.8.0",
"tslib": "^1.10.0",
"uuid": "^3.3.3",
"vkbeautify": "^0.99.3",
"web-animations-js": "^2.3.2",
"webpack-visualizer-plugin": "^0.1.11",
"zone.js": "~0.10.2"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.900.1",
"@angular/cli": "^9.0.1",
"@angular/compiler-cli": "^9.0.0",
"@angular/language-service": "^9.0.0",
"@nguniversal/express-engine": "^8.2.6",
"@types/jasmine": "^3.5.0",
"@types/jasminewd2": "~2.0.8",
"@types/node": "^12.11.1",
"akita-schematics": "^2.0.1",
"codelyzer": "^5.1.2",
"jasmine-core": "~3.5.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "^4.4.1",
"karma-chrome-launcher": "~3.1.0",
"karma-coverage-istanbul-reporter": "^2.1.1",
"karma-jasmine": "~2.0.1",
"karma-jasmine-html-reporter": "^1.4.2",
"protractor": "~5.4.2",
"ts-node": "~8.5.4",
"tslint": "~5.20.1",
"typescript": "^3.7.5",
"webpack-bundle-analyzer": "^3.6.0"
}
}
R3JitReflector.context
中。 (它在哪里寻找它),有时不在那里:
最佳答案
TLDR;如果您收到此错误消息,请确保:
ts.config.json
和 angular.json
文件是最新的。我建议使用 CLI 安装一个新项目,然后并排比较 ts.config.json
或 ts.config.app.json
在两个地方(app
和 src
)确保你是故意这样做的 :-) R3JitReflector
有时会在没有
ɵɵinjectPipeChangeDetectorRef
的情况下实例化在
context
上提供对象,当它到达
resolveExternalReference
它希望找到它但找不到。
R3JitReflector
的堆栈跟踪。后来失败了。
ng serve
),因此我在构造函数中添加了一个带有副作用的鬼鬼祟祟的断点,它会创建一个我以后可以检查的堆栈跟踪)。
this.stack
获取原始堆栈跟踪。这里是:
Error
at eval (eval at R3JitReflector (https://dev.example.com:44300/vendor.js:36828:9), <anonymous>:1:15)
at new R3JitReflector (https://dev.example.com:44300/vendor.js:36828:9)
at CompilerFacadeImpl.push../node_modules/@angular/compiler/fesm5/compiler.js.CompilerFacadeImpl.jitExpression (https://dev.example.com:44300/vendor.js:49155:79)
at CompilerFacadeImpl.push../node_modules/@angular/compiler/fesm5/compiler.js.CompilerFacadeImpl.compileFactory (https://dev.example.com:44300/vendor.js:49134:21)
at Function.get (https://dev.example.com:44300/vendor.js:70418:45)
at eval (ng:///UnobserveHelperService/ɵprov.js:4:110)
at JitEvaluator.push../node_modules/@angular/compiler/fesm5/compiler.js.JitEvaluator.executeFunction (https://dev.example.com:44300/vendor.js:36744:78)
at JitEvaluator.push../node_modules/@angular/compiler/fesm5/compiler.js.JitEvaluator.evaluateCode (https://dev.example.com:44300/vendor.js:36732:21)
at JitEvaluator.push../node_modules/@angular/compiler/fesm5/compiler.js.JitEvaluator.evaluateStatements (https://dev.example.com:44300/vendor.js:36701:21)
at CompilerFacadeImpl.push../node_modules/@angular/compiler/fesm5/compiler.js.CompilerFacadeImpl.jitExpression (https://dev.example.com:44300/vendor.js:49155:37)"
UnobserveHelperService
它具有以下构造函数:
ChangeDetectorRef
这里...
ChangeDetectorRef
是那种你可以注释掉的东西,你的代码基本上仍然可以工作......事实证明就是这样。
UnobserveService
是什么.为了方便起见,它需要一个可观察对象树并将它们“解包”到 POJO。
private
无关紧要,让它成为
public cdr
而是以防万一...... OK 仍然失败 - 正如预期的那样。
@Injectable()
export class UnobserveHelperService implements OnDestroy
{
constructor(public cdr: ChangeDetectorRef)
{
throw new Error('constructor for UnobserveService threw error');
}
UnobserveHelperService
是由组件提供的服务 - 我的失败 URL 之一是
CheckoutComponent
.
providers: [ UnobserveHelperService ]
CheckoutComponent
不
本身 拍
cdr
作为依赖。因此,让我们通过添加
cdr: ChangeDetectorRef
来看看这是否会有所不同。到组件。
@Injectable()
export class UnobserveHelperService
{
constructor(private cdr: ChangeDetectorRef)
{
console.log(this.cdr);
}
}
@Component({
selector: 'app-chat',
templateUrl: './chat.component.html',
styleUrls: ['./chat.component.scss'],
providers: [ UnobserveHelperService ]
})
export class ChatComponent implements OnInit {
constructor(private helper: UnobserveHelperService) {
console.log(this.helper);
}
ngOnInit(): void {
}
}
关于Angular 9 "No value provided for @angular/core symbol ' ɵɵinjectPipeChangeDetectorRef'。”(IVY),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60110226/
我正在尝试使用 flot 绘制 SQL 数据库中的数据图表,这是使用 php 收集的,然后使用 json 编码的。 目前看起来像: [{"month":"February","data":482},
我有一个来自 php 行的 json 结果,类似于 ["value"]["value"] 我尝试使用内爆函数,但得到的结果是“value”“value” |id_kategori|created_at
脚本 1 将记录 two 但浏览器仍会将 select 元素呈现为 One。该表单还将提交值 one。 脚本 2 将记录、呈现和提交 两个。我希望它们是同义词并做同样的事情。请解释它们为何不同,以及我
我的python字典结构是这样的: ips[host][ip] 每行 ips[host][ip] 看起来像这样: [host, ip, network, mask, broadcast, mac, g
在 C# 中 我正在关注的一本书对设置和获取属性提出了这样的建议: double pri_test; public double Test { get { return pri_test; }
您可能熟悉 enum 位掩码方案,例如: enum Flags { FLAG1 = 0x1, FLAG2 = 0x2, FLAG3 = 0x4, FLAG4 = 0x8
在一些地方我看到了(String)value。在一些地方value.toString() 这两者有什么区别,在什么情况下我需要使用哪一个。 new Long(value) 和 (Long)value
有没有什么时候 var result = !value ? null : value[0]; 不会等同于 var result = value ? value[0] : null; 最佳答案 在此处将
我正在使用扫描仪检测设备。目前,我的条形码的值为 2345345 A1。因此,当我扫描到记事本或文本编辑器时,输出将类似于 2345345 A1,这是正确的条形码值。 问题是: 当我第一次将条形码扫描
我正在读取 C# 中的资源文件并将其转换为 JSON 字符串格式。现在我想将该 JSON 字符串的值转换为键。 例子, [ { "key": "CreateAccount", "text":
我有以下问题: 我有一个数据框,最多可能有 600 万行左右。此数据框中的一列包含某些 ID。 ID NaN NaN D1 D1 D1 NaN D1 D1 NaN NaN NaN NaN D2 NaN
import java.util.*; import java.lang.*; class Main { public static void main (String[] args) thr
我目前正在开发我的应用程序,使其设计基于 Holo 主题。在全局范围内我想做的是工作,但我对文件夹 values、values-v11 和 values-v14. 所以我知道: values 的目标是
我遇到了一个非常奇怪的问题。 我的公司为我们的各种 Assets 使用集中式用户注册网络服务。我们一般通过HttpURLConnection使用请求方法GET向Web服务发送请求,通过qs设置参数。这
查询: UPDATE nominees SET votes = ( SELECT votes FROM nominees WHERE ID =1 ) +1 错误: You can't specify
如果我运行一段代码: obj = {}; obj['number'] = 1; obj['expressionS'] = 'Sin(0.5 * c1)'; obj['c
我正在为我的应用创建一个带有 Twitter 帐户的登录页面。当我构建我的项目时会发生上述错误。 values/strings.xml @dimen/abc_text_size_medium
我在搜索引擎中使用以下 View : CREATE VIEW msr_joined_view AS SELECT table1.id AS msr_id, table1.msr_number, tab
为什么验证会返回此错误。如何解决? ul#navigation li#navigation-3 a.current Value Error : background-position Too
我有一个数据名如下 import pandas as pd d = { 'Name' : ['James', 'John', 'Peter', 'Thomas', 'Jacob', 'Andr
我是一名优秀的程序员,十分优秀!