- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我为我的数据表添加了内联编辑数据功能。我正在使用服务调用来获取最新数据,并使用 dtOptions 绑定(bind)到数据表。我正在使用数据表“”。最初为空的数据变量绑定(bind)。一旦我从服务中获取数据,我就会绑定(bind)到绑定(bind)(显示)良好的 dtOptions。但内联编辑不起作用。我不确定从服务中获取数据后如何将数据添加到编辑器。如果我添加 $.fn.dataTable.Editor 的访问实例。它只是不工作。请帮助解决这个问题。
HTML <table id='dtGrid' *ngIf="dtRendered" datatable [dtOptions]="dtOptions" class="row-border hover"></table>
脚本
data = [];
renderDatatable(dtColumns, modelObjAttributes) {
console.log('dtEditor', this.dtEditor);
const colLenth = dtColumns.length;
this.dtRendered = false;
this.dtOptions = {
dom: 'Bfrtip',
data: this.data,
pageLength: 100,
columns: dtColumns,
columnDefs: [ {
targets: colLenth,
defaultContent: '',
title: '<i class="fa fa-plus plusIcon"></i>',
orderable: false
}],
paging: true,
searching: true,
// ordering: true,
info: false,
responsive: true,
drawCallback: () => {
const btnElement = this.dtTableId.nativeElement.querySelector('i.plusIcon');
this.renderer.listen(btnElement, 'click', ($event) => {
this.onClickPlusIcon(modelObjAttributes);
});
},
scrollY: '500px',
// bSort: false,
scrollCollapse: true,
select: {
style: 'os',
selector: 'td:first-child'
},
buttons: [
{ extend: 'create', editor: this.dtEditor },
{ extend: 'edit', editor: this.dtEditor },
{ extend: 'remove', editor: this.dtEditor }
// { extend: 'pageLength', editor: this.dtEditor}
]
};
this.cdr.detectChanges();
this.dtRendered = true;
this.cdr.detectChanges();
this.attachPlusIconClickEvent(modelObjAttributes);
this.attachDtClickEvent();
}
// This method used to initialize the data table dyanamically
initializeDtEditor(dtColumns, modelObjAttributes) {
this.dtEditor = new $.fn.dataTable.Editor({
data: this.data,
table: '#dtGrid',
idSrc: this.uniqueField,
fields: this.dataTableFields,
formOptions: {
inline: {
onBackground: 'blur',
onBlur: 'close',
onComplete: 'close',
onEsc: 'close',
onFieldError: 'focus',
onReturn: 'submit',
submit: 'changed',
scope: 'row'
}
}
});
// this.cdr.detectChanges();
this.renderDatatable(dtColumns, modelObjAttributes);
}
// This method to get the data from service if you see i'm binding the reponseData to dtOptions. It adding to the datatable but it's not allowing to edit(inline edit). with buttong edit it's working.
getData(modelName) {
this.dtServiceService.readData(modelName).subscribe(responseData => {
// console.log(JSON.stringify(data));
this.dtOptions['data'] = responseData;
this.dtRendered = false;
this.cdr.detectChanges();
this.dtRendered = true;
this.cdr.detectChanges();
},
error => {
console.log('data is not getting!');
});
}
最佳答案
Angular-datatables 提供 dt触发器您可以手动使用 触发 表的渲染。
您需要做的是调用 dtTrigger
手动渲染表格。
例子 :
HTML :
<table datatable [dtOptions]="dtOptions" [dtTrigger]="dtTrigger" class="row-border hover">
<thead>
<tr>
<th>ID</th>
<th>First name</th>
<th>Last name</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let person of persons">
<td>{{ person.id }}</td>
<td>{{ person.firstName }}</td>
<td>{{ person.lastName }}</td>
</tr>
</tbody>
</table>
import { Component, OnDestroy, OnInit } from '@angular/core';
import { Http, Response } from '@angular/http';
import { Subject } from 'rxjs';
import { Person } from '../person';
import 'rxjs/add/operator/map';
@Component({
selector: 'app-angular-way',
templateUrl: 'angular-way.component.html'
})
export class AngularWayComponent implements OnDestroy, OnInit {
dtOptions: DataTables.Settings = {};
persons: Person[] = [];
// We use this trigger because fetching the list of persons can be quite long,
// thus we ensure the data is fetched before rendering
dtTrigger: Subject = new Subject();
constructor(private http: Http) { }
ngOnInit(): void {
this.dtOptions = {
pagingType: 'full_numbers',
pageLength: 2
};
this.http.get('data/data.json')
.map(this.extractData)
.subscribe(persons => {
this.persons = persons;
// Calling the DT trigger to manually render the table
this.dtTrigger.next();
});
}
ngOnDestroy(): void {
// Do not forget to unsubscribe the event
this.dtTrigger.unsubscribe();
}
private extractData(res: Response) {
const body = res.json();
return body.data || {};
}
}
关于javascript - 从服务获取数据后如何刷新数据表内联编辑器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60542047/
我想像 wordpress 的 css 管理器一样为我的网站制作 css 管理器。我想在 textarea 中打开 css 文件,这样我就可以编辑它,而不是在按下提交按钮后,应该保存 css 文件中的
我不知道这是一个有效的问题。我见过大多数插件和对话框定义的 CKEditor 示例都使用变量“editor”。我想知道它是什么以及它的值来自哪里。 例如 CKEDITOR.plugins.add( '
如果你希望极认真地学习和使用 XML,那么一定想要找一款称手的 XML 编辑器 XML 是基于文本的 XML是基于文本的标记语言 XML可被类似记事本这样的简单的文本编辑器来创建和编辑 不过在
有没有人成功地将 Summernote 编辑器与 Meteor 一起使用? 见 http://hackerwins.github.io/summernote/ 我在我的模板中包含了以下 div:
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
如何使文本默认从右向左对齐(p:editor)。 当前使用 primefaces 3.0.M2-SNAPSHOT。现在无法更新到新版本吗? 这是阿拉伯语版本应用程序所必需的。 谢谢 最佳答案 在 we
如何启动或安装 Eclipse XSD 编辑器? 根据this看来它应该开箱即用。我创建了 XMLExamples 项目,当我打开 Catalogue.xsd 时,Eclipse 将其视为文本文件。如
我爱wysihtml5但我找不到任何关于向元素添加类这样简单的文档。 基本上我正在寻找的是一种允许 blockquote 元素有 2 种不同变体的方法: blockquote.pull-leftblo
我真的很想要一个在 Django 中实现文本编辑器的清晰直接的示例,就像提议的 pagedown 或 markdownx 一样。我无法在 Django 2.0 中使用这些解决方案中的任何一个,并且我找
是否有支持 REPL 和大括号匹配的 ClojureCLR 编辑器?我找到了一个将对 ClojureCLR 的支持添加到 Visual Studio 的项目:vsClojure ,但无法构建它。还有其
GWT 的编辑器框架非常好用,它不仅可以用于编辑POJO,还可以用于只读显示。 但是,我并不完全确定进行内联编辑的最佳做法是什么。 假设我有一个 PersonProxy 并且我有一对 Presente
我对 primefaces 编辑器的第一个问题是它不接受来自 Chrome 和资源管理器中的 MS word 文档的文本,但在 Firefox 中工作正常。有没有办法让它直接接受来自 MS word
我使用 Prototype JS 作为主要 JS 库,并且我已将最后一个 RedactorJS 与 jQuery 以无冲突模式集成,但我无法启动如下功能: jQuery('#redactor').re
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
我正在 Laravel 项目上使用 redactor 作为文本编辑器。 每当编辑器位于页面上并初始化时,每当我单击任意位置时都会收到此错误。 Uncaught TypeError: $(...).cl
我在带有 jQuery .show("slide") 动画的界面设计中使用tinyMCE 时遇到问题。由于表单的复杂性,它像向导一样被分为多个页面,但它不使用下一步和后退按钮。相反,它使用部分名称
如何制作像 wufoo.com 表单编辑器中那样的拖放式编辑器 最佳答案 通常客户端应用程序是使用某种客户端框架构建的。比较流行的是(排名不分先后): GWT YUI jQuery 首先检查这些内容,
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
有人建议我使用具有语法错误检查和调试功能的 Javascript 编辑器吗? Eclipse IDE 有可用的插件吗?或者您可以建议最适合错误检查和调试的任何编辑器。 提前致谢。 最佳答案 您可以安装
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我是一名优秀的程序员,十分优秀!