Knockout学习(3)之observableArray,监控数组,列表(循环绑定)

ko对于数组列表,监控跟踪属性值关键字为:observableArray,

                         绑定值关键字为:foreach

@{
    ViewBag.Title = "Index3";
}

<h2>Index3</h2>
<head>
    <script src="~/Scripts/jquery-1.10.2.min.js"></script>
    <script src="~/Scripts/KnockOut.js"></script>
    <script>
        $(function () {
            var UserInfos = [
                    { id: 1, name: "张三", age: "21", aclass: "1801" },
                    { id: 2, name: "李四", age: "22", aclass: "1802" },
                    { id: 3, name: "王五", age: "23", aclass: "1803" }
            ];
            var ViewModel = {};
            ViewModel = function ()
            {
                this.UserInfos = ko.observableArray(UserInfos);               
            }
            ko.applyBindings(ViewModel);          
        });
    </script>
</head>
<body>
    <table border="1">
        <thead>
            <tr>
                <td>编号</td>
                <td>姓名</td>
                <td>年龄</td>
                <td>班级</td>
            </tr>
        </thead>
        <tbody data-bind="foreach:UserInfos">
            <tr>
                <td data-bind="text:id"></td>
                <td data-bind="text:(name=='张三'?'张三老师':name)"></td>@*ko里面也可以写逻辑代码:例如当循环到姓名为张三时,输出张三老师;*@
                <td data-bind="text:age"></td>
                <td data-bind="text:aclass"></td>
            </tr>
        </tbody>
    </table>
</body>

展示如下:


我们也可以动态新增,代码如下:

@{
    ViewBag.Title = "Index3";
}

<h2>Index3</h2>
<head>
    <script src="~/Scripts/jquery-1.10.2.min.js"></script>
    <script src="~/Scripts/KnockOut.js"></script>
    <script src="~/Scripts/jquery.json.min.js"></script>
    <script src="~/Scripts/knockout-map.js"></script>
    <script>
        $(function () {
            var UserInfos = [
                    { id: 1, name: "张三", age: "21", aclass: "1801" },
                    { id: 2, name: "李四", age: "22", aclass: "1802" },
                    { id: 3, name: "王五", age: "23", aclass: "1803" }
            ];
            var ViewModel = {};
            ViewModel = function ()
            {
                this.UserInfos = ko.observableArray(UserInfos);
                this.addUser = function ()
                {
                    this.UserInfos.push({ id: -1, name: "新同学", age: "21", aclass: "1801" });
                }
            }
            ko.applyBindings(ViewModel);          
        });
    </script>
</head>
<body>
    <table border="1">
        <thead>
            <tr>
                <td>编号</td>
                <td>姓名</td>
                <td>年龄</td>
                <td>班级</td>
                <td>ko自动排序</td>
            </tr>
        </thead>
        <tbody data-bind="foreach:UserInfos">
            <tr>
                <td data-bind="text:id"></td>
                <td data-bind="text:name"></td>
                <td data-bind="text:age"></td>
                <td data-bind="text:aclass"></td>
                <td data-bind="text:$index"></td>@*这里我新增了一列,在ko里面,有一个自动排序属性:$index,这样循环时,此列的值就会递增*@
            </tr>
        </tbody>
    </table>
    <br />
    <input value="新增" type="button" data-bind="click:addUser" />
</body>

效果如下:


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值