zoukankan      html  css  js  c++  java
  • knockout 简单使用

    定义:

        var QcViewModel = function () {
            var self = this;
            self.name = ko.observable();
            self.qty = ko.observable();
        };
    
         var RecordviewModel =function() {
            var self = this;
            self.temperature = ko.observable('80');
            self.prodname = ko.observable('D成型');
            self.typename = ko.observable('L');
            self.ftargetqty = ko.observable(1000);
            self.prodqty = ko.observable(500);
            self.rate = ko.observable(50);
            self.rateless = ko.observable(50);
    
            self.Detail1 = ko.observableArray([new QcViewModel()]);
            self.Detail2 = ko.observableArray([new QcViewModel()]);
            self.Detail3 = ko.observableArray([new QcViewModel()]);
        };
    
         var myViewModel = new RecordviewModel();

    初始化:

    ko.applyBindings(myViewModel);

    修改值:

    myViewModel.temperature(data.temperature);
    
    var mapping = {
        'Detail1': {
            create: function (options) {
                var newItem = new QcViewModel();
                newItem.name(options.name);
                newItem.qty(options.qty);
                return newItem;
            }
        }, 'Detail2': {
            create: function (options) {
                var newItem = new QcViewModel();
                newItem.name(options.name);
                newItem.qty(options.qty);
                return newItem;
            }
        }, 'Detail3': {
            create: function (options) {
                console.log('Detail3:='+options);
                var newItem = new QcViewModel();
                newItem.name(options.name);
                newItem.qty(options.qty);
                return newItem;
            }
        }
    };
    ko.mapping.fromJS(Detail1, mapping, myViewModel.Detail1);
    ko.mapping.fromJS(Detail2, mapping, myViewModel.Detail2);
    ko.mapping.fromJS(Detail3, mapping, myViewModel.Detail3);

    绑定:

    <span data-bind="text: temperature"></span>

    遍历:

    <div class="col-sm-6 col-md-6" data-bind="foreach: Detail1()">
        <h2> <span style="color:red" data-bind="text: qty">90</span> <span style="color:greenyellow" data-bind="text: name"></span></h2>
    </div>
  • 相关阅读:
    【Winform】Find out the changed rows in DataGridView
    DataGridView merge colunm header
    Spread日付セールのカレンダーに本日を初期値として表示する
    JLPT
    sql server数据库是否区分大小写的设置
    IIS7に.NET Framework 4を登録する
    [翻译]使用ASP.NET AJAX让GridView的数据行显示提示框(ToolTip)
    SILVERLIGHT开始在整个网站积累更深入的体验(转载)
    net连接access数据库,输出结果到页面
    利用JavaScript实现简单的拖动层(只使用于IE)
  • 原文地址:https://www.cnblogs.com/CoreXin/p/knockout.html
Copyright © 2011-2022 走看看