zoukankan      html  css  js  c++  java
  • Knockout.js 组件

    Knockout.js是一个基于MVVM模式的轻量级的前端框架,有多轻?根据官网上面显示的最新版本v3.4.0,仅22kb。能够友好地处理数据模型和界面DOM的绑定,最重要的是,它的绑定是双向的,也就是说数据模型变化了,界面DOM上的数据也会跟着发生变化,反过来,界面DOM上的数据变化了,数据模型也会相应这个变化

    Knockout.js官网:http://knockoutjs.com

    Knockout.js开源地址:https://github.com/knockout/knockout

    MVVM模式:这是一种创建用户界面的设计模式,MVVM把它拆分成三块就是Model、View、ViewModel,Model就是数据模型,View就是我们的视图,ViewModel就是一个视图模型,用来绑定数据模型和视图上面的dom元素。

    实例

    官网下载knockout.js文件,然后引用到view页面里面

    <script src="~/scripts/knockout/knockout-3.4.0.js"></script>

    完整案例

    <!DOCTYPE html>
    <html>  
    <#include "../include.ftl">
    <head>  
        <meta charset="utf-8">  
        <title>test</title>
        <script src="${basePath}/scripts/jquery/jquery-1.9.0.min.js"></script>
        <script src="${basePath}/scripts/knockout/knockout-3.4.0.js"></script>
    </head> 
    <body>
    <div> 
        <!-- view视图里面定义绑定data-bind的标签 ;注意:对应input标签的文本,需要使用textinput,而普通标签的文本使用text即可。-->
            From:<label data-bind="text:From"></label><br />
            To:<input type="text" data-bind="textinput:To" />
        </div>
    
    </body>  
    </html>  
    <script type="text/javascript">
      //定义一个viewmodel:Name,Profession标签与html元素标签区分大小写
        var myViewModel = {
                From: "去了",
                To: "来了",
            };
      //需要激活knockout的绑定
        ko.applyBindings(myViewModel);
    </script>

    效果

    ko.applyBindings()方法有两个参数,第一个就是我们需要绑定的viewmodel
    第二个参数是一个可选参数,它表示viewmodel绑定的标签的作用域
    ko.applyBindings(myViewModel,document.getElementById("ID"));

    第二个参数限定了myViewModel的作用范围,也就是说,只有在id="lb_name"的标签上面绑定才会生效,如果第二个参数是div等容器标签,它表示该绑定的范围为该div下面的所有子标签。

    其他详看:http://www.cnblogs.com/landeanfen/p/5400654.html

  • 相关阅读:
    Sql Server 2008 为开发带来的新特性
    MSMQ 与ESB
    面向服务架构(SOA)和企业服务总线(ESB)
    IBM网站 构建您的SOA 系列文章
    Visual Studio 2008 和 .NET Framework 3.5 Training Kit
    模式与实践 系列发布WCF Security Guidance 1.0
    跟NHibernate之夏一起学习NHibernate
    ORACLE一些不常用的脚本
    ORACLE已建表能否创建分区
    Access数据库问题锦集
  • 原文地址:https://www.cnblogs.com/hwaggLee/p/6019378.html
Copyright © 2011-2022 走看看