如何在jquery中更快地进行UI更新

时间:2014-12-11 08:17:04

标签: jquery asp.net json

我有一个表格,用于显示用户选择的日期范围的生产预测。该表由 40列和大约1000行。

我已经制作了一些可编辑的列,以便对计划进行更改。将使用ajax和json [哪个属性和值是什么]在服务器中报告此更改。服务器将重新计算并将表值更改以json格式报告给客户端[column no,rowno,value]。

我遍历json数组并像

一样更新表
$("#GridViewPlan tr:eq(" + (myRow) + ") td:eq(" + myCol + ")").text(val);

但是我的问题是for循环中的上述句子(ui更新)需要时间

如何改进此架构?是否有类似于快速UI更新的jquery库

1 个答案:

答案 0 :(得分:0)

您可以使用KnockoutJS另一个使用MVVM模式的JavaScript库。它将使您轻松,快速地进行数据绑定。有关详细信息,请阅读official documentation 很酷的是你可以同时使用jQuery和KnockoutJS。对于具有大量记录的表,您可能希望启用这样的分页:

<强> HTML

<div data-bind='simpleGrid: gridViewModel'> </div>

<button data-bind='click: addItem'>
    Add item
</button>

<button data-bind='click: sortByName'>
    Sort by name
</button>

<button data-bind='click: jumpToFirstPage, enable: gridViewModel.currentPageIndex'>
    Jump to first page
</button>

和javascript:

<script>
    var initialData = [
        { name: "Well-Travelled Kitten", sales: 352, price: 75.95 },
        { name: "Speedy Coyote", sales: 89, price: 190.00 },
        { name: "Furious Lizard", sales: 152, price: 25.00 },
        { name: "Indifferent Monkey", sales: 1, price: 99.95 },
        { name: "Brooding Dragon", sales: 0, price: 6350 },
        { name: "Ingenious Tadpole", sales: 39450, price: 0.35 },
        { name: "Optimistic Snail", sales: 420, price: 1.50 }
    ];

    var PagedGridModel = function(items) {
        this.items = ko.observableArray(items);

        this.addItem = function() {
            this.items.push({ name: "New item", sales: 0, price: 100 });
        };

        this.sortByName = function() {
            this.items.sort(function(a, b) {
                return a.name < b.name ? -1 : 1;
            });
        };

        this.jumpToFirstPage = function() {
            this.gridViewModel.currentPageIndex(0);
        };

        this.gridViewModel = new ko.simpleGrid.viewModel({
            data: this.items,
            columns: [
                { headerText: "Item Name", rowText: "name" },
                { headerText: "Sales Count", rowText: "sales" },
                { headerText: "Price", rowText: function (item) { return "$" + item.price.toFixed(2) } }
            ],
            pageSize: 4
        });
    };

    ko.applyBindings(new PagedGridModel(initialData));
</script>

以下是fiddle