angular - 将自定义元素和属性添加到编译器模式

标签 angular angular2-compiler

组件模板中有一些自定义元素和属性(在本例中它们被第三方非 Angular 代码使用):

<foo></foo>
<div data-bar="{{ bar }}"></div>

它们会导致编译器错误:

Template parse errors:
'foo' is not a known element:
1. If 'foo' is an Angular component, then verify that it is part of this module.
2. If 'foo' is a Web Component then add "CUSTOM_ELEMENTS_SCHEMA" to the '@NgModule.schemas' of this component to suppress this message. ("
    [ERROR ->]<foo></foo>
    <div data-bar="{{ bar }}"></div>
  "): App@1:4
Can't bind to 'bar' since it isn't a known property of 'div'. ("
    <foo></foo>
    <div [ERROR ->]data-bar="{{ bar }}"></div>
  ")
...

如何将 foo 元素和 data-bar 属性添加到编译模式?

NO_ERRORS_SCHEMA 不是一个选项,因为不希望将其他未知元素和属性列入白名单。

最佳答案

您可以像这样尝试覆盖 DomElementSchemaRegistry:

import { DomElementSchemaRegistry, ElementSchemaRegistry } from '@angular/compiler'
import { SchemaMetadata } from '@angular/core';

const MY_DOM_ELEMENT_SCHEMA = [
  'foo'
];

const MY_CUSTOM_PROPERTIES_SCHEMA = {
  'div': {
    'bar': 'string'
  }
};

export class CustomDomElementSchemaRegistry extends DomElementSchemaRegistry {
  constructor() {
    super();
  }

  hasElement(tagName: string, schemaMetas: SchemaMetadata[]): boolean {
    return MY_DOM_ELEMENT_SCHEMA.indexOf(tagName) > -1 || 
         super.hasElement(tagName, schemaMetas);
  }

  hasProperty(tagName: string, propName: string, schemaMetas: SchemaMetadata[]): boolean {
    const elementProperties = MY_CUSTOM_PROPERTIES_SCHEMA[tagName.toLowerCase()];
    return (elementProperties && elementProperties[propName]) || 
        super.hasProperty(tagName, propName, schemaMetas);
  }
}

platformBrowserDynamic().bootstrapModule(AppModule, {
  providers: [{ provide: ElementSchemaRegistry, useClass: CustomDomElementSchemaRegistry }]
});

Plunker Example

关于angular - 将自定义元素和属性添加到编译器模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42953118/

相关文章:

angular - 等价于 Angular 2 中的 $compile

Angular 2 RC 6 AoT 编译器不工作

升级到 RC5 后,Angular2 通用错误找不到模块 '@angular/compiler/src/template_parser'

angular - 中心垫菜单,中心垫菜单覆盖到按钮

javascript - 如何在 Angular 分量中嵌入vimeo视频?

javascript - 初始化自定义类

angular - 如何在 Angular2 编译器/cli ngc 命令中使用 RouterModule.forRoot()

Angular2 没有 CompileMetadataResolver 的提供者

javascript - 使用 jQuery 的 Angular 2+ 服务器端渲染

html - ngForm 或纯 HTML 表单 - 使用 *ngFor 进行可变长度输入