- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个可重用的组件来呈现表格。它目前适用于基本表格,但在某些情况下我希望能够自定义表格中的单个列/单元格。
这是我在父组件中使用的代码:
<!-- PARENT TEMPLATE -->
<app-table
[headers]="headers"
[keys]="keys"
[rows]="rows">
</app-table>
// PARENT COMPONENT
public headers: string[] = ['First', 'Last', 'Score', 'Date'];
public keys: string[] = ['firstName', 'lastName', 'quizScore', 'quizDate'];
public rows: Quiz[] = [
{ 'John', 'Doe', 0.75, '2020-01-03T18:18:34.549Z' },
{ 'Jane', 'Doe', 0.85, '2020-01-03T18:19:14.893Z' }
];
以及我在子组件中使用的代码:
<!-- CHILD TEMPLATE -->
<table>
<thead>
<tr>
<td *ngFor="let header of headers">
{{ header }}
</td>
</tr>
</thead>
<tbody>
<tr *ngFor="let row of rows">
<td *ngFor="let key of keys">
{{ render(key, row) }}
</td>
</tr>
</tbody>
</table>
// CHILD COMPONENT
@Input() headers: string[];
@Input() keys: string[];
@Input() rows: any[];
render(key: string, row: any) {
return row['key'];
}
我希望能够在父组件中声明一个模板来修改子组件中的数据。例如,将测验分数转换为百分比或格式化日期,而不直接更改组件中的数据。我设想类似以下内容:
<ng-template #quizScore>
{{ someReferenceToData | percent }} // This treatment gets passed to child
</ng-template>
通过将其传递到我的子组件中,它将获取我渲染的数据并使用百分比管道对其进行格式化。我对 ngTemplateOutlet 、 ngComponentOutlet 、 ng-content 等进行了一些研究,但不确定最好的方法。
最佳答案
您需要将 TemplateRef
从父组件传递到子(表)组件。根据您当前的方法,一种方法是为父组件中的 @ViewChild
引用创建另一个数组,并将其传递给表组件。
但是,我建议通过为列配置创建一个接口(interface)进行一些重构,该接口(interface)具有 header
、key
以及可选的 customCellTemplate
。像这样的东西:
import { TemplateRef } from '@angular/core';
export interface TableColumnConfig {
header: string;
key: string;
customCellTemplate?: TemplateRef<any>;
}
然后您可以简化子组件的输入
// CHILD COMPONENT
@Input() columnConfigs: TableColumnConfig[];
@Input() rows: any[];
您对父级中自定义单元格模板定义的愿景是正确的,但您需要访问数据。
HTML
<app-table
[columnConfigs]="columnConfigs"
[rows]="rows">
</app-table>
<!-- name the $implicit variable 'let-whateverIwant', see below for where we set $implicit -->
<!-- double check variable spelling with what you are trying to interpolate -->
<ng-template #quizScore let-someReferenceToData>
{{ someReferenceToData | percent }} // The parent component can do what it likes to the data and even styles of this cell.
</ng-template>
TS - 模板引用在 ngOnInit
/ngAfterViewInit
生命周期 Hook 之前未定义
// PARENT COMPONENT
@ViewChild('quizScore', { static: true }) customQuizTemplate: TemplateRef<any>;
public columnConfigs: TableColumnConfiguration[];
public rows: Quiz[] = [
{ 'John', 'Doe', 0.75, '2020-01-03T18:18:34.549Z' },
{ 'Jane', 'Doe', 0.85, '2020-01-03T18:19:14.893Z' }
];
ngOnInit() {
this.columnConfigs = [
{key: 'firstName', header: 'First'},
{key: 'lastName', header: 'Last'},
{key: 'quizScore', header: 'Score', customCellTemplate: customQuizTemplate},
{key: 'quizDate', header: 'Date'}
]
}
关于 static:true
与 static:false
的注意事项 - 模板引用是静态的,除非它是用 * 之类的东西动态渲染的ngIf
或 *ngFor
。 static:true
将在 ngOnInit
中初始化模板引用,static:false
将在 ngAfterViewInit
中初始化它。
您已经在表格中放置了嵌套的 *ngFor,但如果有 customCellTemplate,则需要进行一些内容投影。
<tr *ngFor="let row of rows">
<td *ngFor="let col of columnConfigs">
<!-- if there is no customCellTemplate, just render the data -->
<div *ngIf="!col.customCellTemplate; else customCellTemplate">
{{ render(col.key, row) }}
</div>
<ng-template #customCellTemplate>
<!-- expose data, you could expose entire row if you wanted. but for now this only exposes the cell data -->
<ng-template [ngTemplateOutlet]="col.customCellTemplate"
[ngTemplateOutletContext]="{ $implicit: {{ render(col.key, row) }} }">
</ng-template>
</ng-template>
</td>
</tr>
旁注:如果可以的话,我会将 render(col.key, row)
替换为 row[col.key]
。
关于angular - 将 ng-template 传递给子组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59583563/
template struct List { }; template class> struct ListHelper; template struct ListHelper> { };
最近,我注意到 html/template.Template 的 Templates() 与 text/template.Template 的工作方式不同。 // go1.12 func main()
我正在尝试使用 polymer 1.0 实现一个网站。我有一个自定义元素 my-greeting,里面有一些模板重复。 我想做的是获取一个名为 TARGET 的字符串,但我不知道该怎么做: /cons
(是的,由于我糟糕的英语,标题很奇怪;我希望有人能改进它。) 接听this question ,我发现这段代码有效: template class A { }; template class U>
这个问题在这里已经有了答案: How to import and use different packages of the same name (2 个答案) 关闭 4 年前。 我正在使用 Go
我的想法是这是不可能的,或者我缺少一个额外的步骤。无论哪种方式,我都被卡住了,无法弄清楚。 使用内联模板的原因是能够使用 Laravel Blade 语法并结合 Vue Js 的强大功能。似乎是两者中
我已经尝试实现一个“模板模板模板”——模板类来满足我的需求(我对使用模板元编程很陌生)。不幸的是,我发现以下主题为时已晚: Template Template Parameters 不过,我需要实现如
Helm _helpers.tpl? Helm 允许使用 Go templating在 Kubernetes 的资源文件中。 一个名为 _helpers.tpl 的文件通常用于定义 Go 模板助手,语
{{template "base"}} 和 {{template "base".}} 有什么区别? 我用的是go-gin,两者都可以正常运行。我在文档中找不到关于此的任何描述。 最佳答案 来自 god
我有一个本质上充当查找表的函数: function lookup(a::Int64, x::Float64, y::Float64) if a == 1 z = 2*x + y else if a =
当 out 成员函数(来自模板和特化)都需要模板时,为什么 c++ 需要模板参数,因为我没有得到它,谷歌也没有帮助。必须是c++11但和c++1z有同样的错误。 我正在使用 g++ 7.3.0 收到此
我正在寻找简单的方法来将带有 ${myvar} 的简单模板转换为带有 {{ myvar }} 的 GO 模板。 是否有任何库可以实现这一点? 最佳答案 使用正则表达式查找 \${([a-z0-9\_\
我有这个模板可以将 slice 的多个项目解析到页面上。它确实做得很好。 但是,我现在想使用完全相同的模板来根据范围索引解析 slice 的单个值。该 slice 在多个文件中使用,所以我不能像 Sl
要清理模板文件夹,我想将常用模板保存在子文件夹中。目前我有以下文件结构: main.go templates/index.tpl # Main template for the
最近我设计了元类型和允许编译时类型连接的可能操作: #include template typename T> struct MetaTypeTag {}; /*variable template
准备模板时发生错误。谁能告诉你怎么修? 如有必要,还可以编辑变量。 vars: AllСountry: - "name1" - "name2"
我在使用新的匿名模板引擎时遇到问题。它不能使用嵌套模板。我收到错误消息:“此模板引擎不支持嵌套在其模板中的匿名模板”。 我的问题:我如何强制 knockout JS 使用jquery 模板引擎,而不是
这个问题在这里已经有了答案: Where and why do I have to put the "template" and "typename" keywords? (8 个答案) 关闭 8
我在 C++ 中使用带有模板的集合: template class OMSSVDisk : public OMSSObjProperties{ set memberPDs; }; 如上面代码中
因为我喜欢分离接口(interface)和实现,而不是只在头文件中实现模板类,我将它分成 .h 和 .tpp(.tpp 这样它就不会用 *.cpp 编译)。然后我将 tpp 包含在头文件的末尾,就在
我是一名优秀的程序员,十分优秀!