html - Angular 2 在动态生成的 "list"中向新元素添加高亮显示

标签 html css typescript angular2-forms

我有一个连接数组,我使用 angular 2 和 typescript 显示这些连接,如下所示:

 <div class="list-item" *ngFor="let con of connectors; let i = index" id="con{{i}}" (click)="connectorSelected(con,i)">
                <label class="list-name">{{con.name || "No Available Name"}}</label>
                <label class="list-desc">{{con.description}}</label>
 </div>

所以基本上当我选择一个连接时,它会在 typescript 中的 typescript 函数 connectorSelected 中突出显示。

private connectorSelected(con: ConnectorModel, index: number) {
        this.removeSelectionOnAllFields();
        let selectedElement = document.getElementById("con" + index);
        selectedElement.className += " selected"
        this.conStatus = SaveStatus.UptoDate;
 }

private removeSelectionOnAllFields() {
    let allClassesHaveSelected = document.getElementsByClassName("selected");
    while (allClassesHaveSelected.length) {
        allClassesHaveSelected[0].classList.remove("selected");
    }
}

但是,当我创建一个新连接时。我向列表中添加一个新连接并尝试突出显示该新创建的连接,但问题是新创建的连接尚未在 HTML5 网页中呈现。这会导致页面抛出错误,因为我们添加到数组的新连接器尚未在 html 页面中创建。因此还没有元素存在,它只是在执行完整个函数后才在网页中创建元素。

新的连接代码:

 private newConnector(): void {

    let newConenctor: ConnectorModel = new ConnectorModel();
    this.connectors.push(newConenctor);
    let index: number = this.connectors.length - 1;
    this.removeSelectionOnAllFields();
    let selectedElement = document.getElementById("con" + index);
    selectedElement.className += " selected"
}

我想知道我应该如何处理这个问题?

最佳答案

这是因为 Angular 不触发变化检测。

为了解决这个问题,你应该复制你的数组。

this.connectors.push(newConenctor);
this.connectors = this.connectors.slice(0);

否则就像我在评论中所说的那样,我建议您使用指令 [ngClass],它更简单,您不必使用全局文档。

您可以在此处找到文档:https://angular.io/docs/ts/latest/api/common/index/NgClass-directive.html

关于html - Angular 2 在动态生成的 "list"中向新元素添加高亮显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44056154/

相关文章:

javascript - 自定义 html 标签——有更好的方法吗?

python - 如何在Plone中注入(inject)模板代码?

javascript - 如何在 HTML 选项中换行文本

javascript - 如何在 JavaScript 插件中使用 CSS 动画?

html - Bootstrap float 将元素放到第二行

html - 在 Twitter Bootstrap 3.1 中重新排序 div 未按预期工作

html - 鼠标悬停时弹出的按钮的 css 样式存在问题

Angular-cli 和 Ckeditor4 自定义构建

typescript - 有没有办法在初始化时在nextjs中同时配置tailwind和typescript?

Javascript:根据多个值过滤对象数组