- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是一名 Angular 新手,尝试使用 Material 2 实现表驱动的级联菜单,但当我尝试使用变量将 mat-menu 元素名称的值分配给 [matMenuTriggerFor] 时,出现运行时错误。我找到的所有示例都使用文本字符串来指定 mat-menu 元素名称;我无法在网络上的任何地方找到表明其他人遇到类似问题的帖子,尽管我确实在 github 上找到了几个月前的帖子,报告为绑定(bind)到 [matMenuTriggerFor] 不起作用的错误,但它已被关闭作为与 Material 版本 4.x.x 相关的问题。看来 [matMenuTriggerFor] 需要表达式的值,但我的尝试不起作用。我做错了什么?
我使用的是 Win 10,浏览器是 Firefox 57.0.2
我的 Angular 版本:
Angular CLI: 1.5.0
Node: 6.11.3
OS: win32 x64
Angular: 5.1.2
... animations, common, compiler, compiler-cli, core, forms
... http, language-service, platform-browser
... platform-browser-dynamic, router
@angular/cdk: 5.0.2
@angular/cli: 1.5.0
@angular/material: 5.0.2
@angular-devkit/build-optimizer: 0.0.36
@angular-devkit/core: 0.0.22
@angular-devkit/schematics: 0.0.42
@ngtools/json-schema: 1.1.0
@ngtools/webpack: 1.8.0
@schematics/angular: 0.1.11
@schematics/schematics: 0.0.11
typescript: 2.4.2
webpack: 3.8.1
我的app.module.ts:
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { MatMenuModule } from '@angular/material/menu';
import { MatToolbarModule } from '@angular/material/toolbar';
import { MatIconModule } from '@angular/material/icon';
import { MatListModule } from '@angular/material/list';
import { AppComponent } from './app.component';
import { NestedMenusComponent } from './nested-menus/nested-menus.component';
@NgModule({
declarations: [
AppComponent,
NestedMenusComponent
],
imports: [
BrowserModule,
BrowserAnimationsModule,
MatMenuModule,
MatToolbarModule,
MatIconModule,
MatListModule,
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
我的组件.ts:
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-nested-menus',
templateUrl: './nested-menus.component.html',
styleUrls: ['./nested-menus.component.scss']
})
export class NestedMenusComponent implements OnInit {
constructor() { }
ngOnInit() { }
selected :string;
menuItems = [
{text: "Tabledriven.Item1" },
{text: "Tabledriven.Item2", templateName: "submenu"},
];
select(pText :string)
{
this.selected = pText;
}
}
我的组件.html:
<div>
<p>You selected: {{ selected }}</p>
<div class="demo-menu">
<div class="menu-section">
<p>Basic Menu</p>
<mat-toolbar>
<button mat-icon-button [matMenuTriggerFor]="basic">
<mat-icon>more_vert</mat-icon>
</button>
</mat-toolbar>
<mat-menu #basic="matMenu">
<button mat-menu-item (click)="select('Basic.Item1')">Basic.Item1</button>
<button mat-menu-item [matMenuTriggerFor]="submenu">Basic.Item2</button>
</mat-menu>
</div>
<div class="menu-section">
<p>Table-driven Menu</p>
<mat-toolbar>
<button mat-icon-button [matMenuTriggerFor]="tabledriven">
<mat-icon>more_vert</mat-icon>
</button>
</mat-toolbar>
<mat-menu #tabledriven="matMenu">
<ng-container *ngFor="let item of menuItems">
<button *ngIf=!item.templateName mat-menu-item (click)="select(item.text)">{{ item.text }}</button>
<button *ngIf=item.templateName mat-menu-item [matMenuTriggerFor]=item.templateName>{{ item.text }}</button>
</ng-container>
</mat-menu>
</div>
<mat-menu #submenu="matMenu">
<button mat-menu-item (click)="select('Submenu.Item1')">Submenu.Item1</button>
<button mat-menu-item (click)="select('Submenu.Item2')">Submenu.Item2</button>
</mat-menu>
</div>
</div>
表格驱动的菜单在任何用户输入之前抛出运行时错误:
ERROR
TypeError: this.menu.close is undefined
Stack trace:
MatMenuTrigger.prototype.ngAfterContentInit@webpack-internal:///../../../material/esm5/menu.es5.js:771:9
callProviderLifecycles@webpack-internal:///../../../core/esm5/core.js:12929:9
callElementProvidersLifecycles@webpack-internal:///../../../core/esm5/core.js:12903:13
callLifecycleHooksChildrenFirst@webpack-internal:///../../../core/esm5/core.js:12886:29
checkAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14036:5
callViewAction@webpack-internal:///../../../core/esm5/core.js:14383:21
execEmbeddedViewsAction@webpack-internal:///../../../core/esm5/core.js:14341:17
checkAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14033:5
callViewAction@webpack-internal:///../../../core/esm5/core.js:14383:21
execEmbeddedViewsAction@webpack-internal:///../../../core/esm5/core.js:14341:17
checkAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14033:5
callViewAction@webpack-internal:///../../../core/esm5/core.js:14383:21
execComponentViewsAction@webpack-internal:///../../../core/esm5/core.js:14315:13
checkAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14038:5
callViewAction@webpack-internal:///../../../core/esm5/core.js:14383:21
execComponentViewsAction@webpack-internal:///../../../core/esm5/core.js:14315:13
checkAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14038:5
callWithDebugContext@webpack-internal:///../../../core/esm5/core.js:15286:39
debugCheckAndUpdateView@webpack-internal:///../../../core/esm5/core.js:14823:12
ViewRef_.prototype.detectChanges@webpack-internal:///../../../core/esm5/core.js:11797:13
ApplicationRef.prototype.tick/<@webpack-internal:///../../../core/esm5/core.js:6104:58
ApplicationRef.prototype.tick@webpack-internal:///../../../core/esm5/core.js:6104:13
ApplicationRef.prototype._loadComponent@webpack-internal:///../../../core/esm5/core.js:6170:9
ApplicationRef.prototype.bootstrap@webpack-internal:///../../../core/esm5/core.js:6058:9
PlatformRef.prototype._moduleDoBootstrap/<@webpack-internal:///../../../core/esm5/core.js:5778:74
PlatformRef.prototype._moduleDoBootstrap@webpack-internal:///../../../core/esm5/core.js:5778:13
PlatformRef.prototype.bootstrapModuleFactory/</</<@webpack-internal:///../../../core/esm5/core.js:5699:21
ZoneDelegate.prototype.invoke@webpack-internal:///../../../../zone.js/dist/zone.js:392:17
onInvoke@webpack-internal:///../../../core/esm5/core.js:4949:24
ZoneDelegate.prototype.invoke@webpack-internal:///../../../../zone.js/dist/zone.js:391:17
Zone.prototype.run@webpack-internal:///../../../../zone.js/dist/zone.js:142:24
scheduleResolveOrReject/<@webpack-internal:///../../../../zone.js/dist/zone.js:873:52
ZoneDelegate.prototype.invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:425:17
onInvokeTask@webpack-internal:///../../../core/esm5/core.js:4940:24
ZoneDelegate.prototype.invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:424:17
Zone.prototype.runTask@webpack-internal:///../../../../zone.js/dist/zone.js:192:28
drainMicroTaskQueue@webpack-internal:///../../../../zone.js/dist/zone.js:602:25
NestedMenusComponent.html:29:10
View_NestedMenusComponent_3
NestedMenusComponent.html:29:10
DebugContext_.prototype.logError
core.js:15030
ErrorHandler.prototype.handleError
core.js:1488
ApplicationRef.prototype.tick/<
core.js:5915:54
ZoneDelegate.prototype.invoke
zone.js:392
Zone.prototype.run
zone.js:142
NgZone.prototype.runOutsideAngular
core.js:4701:47
ApplicationRef.prototype.tick
core.js:5915
ApplicationRef.prototype._loadComponent
core.js:5974
ApplicationRef.prototype.bootstrap
core.js:5862
PlatformRef.prototype._moduleDoBootstrap/<
core.js:5582:65
PlatformRef.prototype._moduleDoBootstrap
core.js:5582
PlatformRef.prototype.bootstrapModuleFactory/</</<
core.js:5503
ZoneDelegate.prototype.invoke
zone.js:392
onInvoke
core.js:4753
ZoneDelegate.prototype.invoke
zone.js:391
Zone.prototype.run
zone.js:142
scheduleResolveOrReject/<
zone.js:873
ZoneDelegate.prototype.invokeTask
zone.js:425
onInvokeTask
core.js:4744
ZoneDelegate.prototype.invokeTask
zone.js:424
Zone.prototype.runTask
zone.js:192
drainMicroTaskQueue
zone.js:602
ERROR CONTEXT
Object { view: {…}, nodeIndex: 2, nodeDef: {…}, elDef: {…}, elView: {…} }
NestedMenusComponent.html:29:10
Angular is running in the development mode. Call enableProdMode() to enable the production mode.
core.js:3660
[WDS] Disconnected!
client:164
基本菜单按需要工作。当打开表驱动菜单时,会显示菜单的两个项目,第二个项目包含指示它公开子菜单的图标,但会引发以下运行时错误:
ERROR
TypeError: templateRef is undefined
Stack trace:
ViewContainerRef_.prototype.createEmbeddedView@webpack-internal:///../../../core/esm5/core.js:11626:30
DomPortalOutlet.prototype.attachTemplatePortal@webpack-internal:///../../../cdk/esm5/portal.es5.js:448:40
BasePortalOutlet.prototype.attach@webpack-internal:///../../../cdk/esm5/portal.es5.js:303:20
OverlayRef.prototype.attach@webpack-internal:///../../../cdk/esm5/overlay.es5.js:647:45
MatMenuTrigger.prototype.openMenu@webpack-internal:///../../../material/esm5/menu.es5.js:861:13
MatMenuTrigger.prototype._handleClick@webpack-internal:///../../../material/esm5/menu.es5.js:1185:13
View_NestedMenusComponent_3/<@ng:///AppModule/NestedMenusComponent.ngfactory.js:64:23
handleEvent@webpack-internal:///../../../core/esm5/core.js:13777:115
callWithDebugContext@webpack-internal:///../../../core/esm5/core.js:15286:39
debugHandleEvent@webpack-internal:///../../../core/esm5/core.js:14873:12
dispatchEvent@webpack-internal:///../../../core/esm5/core.js:10186:16
renderEventHandlerClosure/<@webpack-internal:///../../../core/esm5/core.js:10807:38
decoratePreventDefault/<@webpack-internal:///../../../platform-browser/esm5/platform-browser.js:2679:53
ZoneDelegate.prototype.invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:425:17
onInvokeTask@webpack-internal:///../../../core/esm5/core.js:4940:24
ZoneDelegate.prototype.invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:424:17
Zone.prototype.runTask@webpack-internal:///../../../../zone.js/dist/zone.js:192:28
ZoneTask.invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:499:24
invokeTask@webpack-internal:///../../../../zone.js/dist/zone.js:1540:9
globalZoneAwareCallback@webpack-internal:///../../../../zone.js/dist/zone.js:1566:17
NestedMenusComponent.html:29:10
ERROR CONTEXT
Object { view: {…}, nodeIndex: 0, nodeDef: {…}, elDef: {…}, elView: {…} }
NestedMenusComponent.html:29:10
最佳答案
关于angular - 使用变量将 mat-menu 元素指定为 [matMenuTriggerFor]?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47965268/
我已经彻底搜索过,但没有找到直接的答案。 将 opencv 矩阵 (cv::Mat) 作为参数传递给函数,我们传递的是智能指针。我们对函数内部的输入矩阵所做的任何更改也会改变函数范围之外的矩阵。 我读
是否可以有一个垫子分隔线(一条水平线分隔两个垫子选项)? 我试过: Cars Volvo Saab Mercedes Audi
使用的浏览器 - Chrome 67.0.3396.99 我创建了一个 DialogsModule它有一个组件 ConfirmDialog.component.ts使用以下模板 confirm-dia
我正在尝试使用 mat-toolbar 但出现错误: mat-menu.component.html: Responsive Navigation Menu I
我正在创建 angular 7 网络应用程序,并使用一个 mat-select 下拉菜单和一个 mat-paginator。现在我隐藏 mat-select 向下箭头。 Here is the mat
在我的应用程序中,我有一个通过引用接收 cv::Mat 对象的函数。这是函数的声明: void getChains(cv::Mat &img,std::vector &chains,cv::
我使用了独立的 EMA (1.5.0) 和 eclipse 插件(在 eclipse 4.5 中)来分析我的堆转储。 我想查看任何无法访问的对象信息,我已尝试在我的首选项和命令行选项 -keep_un
我是 flex 的新手,我的垫子 table 做得很好。 不幸的是,我的标题没有遵循我的单元格宽度。 这是我的结果的图片。 如您所见,我的标题与我的单元格不对齐。 这是我的 CSS 代码,就像我说我是
我试图在我的 Material 表上使用 mat-sort 和 mat-paginator,但似乎不起作用。 Table 确实获取了 dataSource.data 中的数据,它也显示在 mat-ta
我试图在我的 Material 表上使用 mat-sort 和 mat-paginator,但似乎不起作用。 Table 确实获取了 dataSource.data 中的数据,它也显示在 mat-ta
我想在每个 mat-option 文本上设置悬停样式,我希望文本显示在 mat-option 之外。为了实现这一点,我应用了非常高的 z-index 值,但没有任何改变。我尝试将 z-index 添加
默认情况下 mat-drawer-container/mat-sidenav-container 和 mat-drawer/mat-sidenav 高度基于 mat-drawer-cont
在 mat-card-header 中提供图像头像通过 mat-card-avatar 得到很好的支持. 在许多用例中,我们希望使用图标而不是图像作为卡片的“头像”。 有没有一种简单的方法可以用图标替
我想要一个包含 2 列的网格列表,并且在这些列中我想要 2 个垂直堆叠的复选框。 我看过 this question 这确实有点 工作,但我想知道是否有更简洁的方法解决这个问题,因为我必须使用大量的
更新:stackbliz https://angular-2wqf4b.stackblitz.io 我正在构建一个比较屏幕,我们可以在其中比较两个项目。我试图将这两项显示为两个 mat-cards里
试图模仿 Material guide 的外观,我无法让工具栏的阴影呈现在 mat-sidenav-container 元素之上: 显示工具栏和 sidenav 的页面,但投影不可见: 单独显示工具栏
请注意,分页/排序无法正常工作。分页不显示它显示的元素数量并且排序不起作用,但是如果您删除 html 文件中的行 *ngIf="dataSource?.filteredData.length > 0"
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Proper stack and heap usage in C++? Heap vs Stack allo
单击每个单选按钮时,我需要为每个垫卡添加背景。背景应仅适用于与单击的垫单选按钮对应的垫卡。
Mat a = (Mat_(3,3) = 2 int dims; //! the number of rows and columns or (-1, -1) when the arr
我是一名优秀的程序员,十分优秀!