zoukankan      html  css  js  c++  java
  • 关于学习Knockoutjs--入门(一)

      前段时间做项目一直在用knockout,虽然用着不怎么利索,但是知识是一点一点探索的。

      首先介绍一下 Knockout是什么?

      他是一个很优秀的js库,他最大的功能就是实现双向绑定,它可以帮助你仅使用一个清晰整洁的底层数据模型(data model)即可创建一个富文本且具有良好的显示和编辑功能的用户界面。任何时候你的局部UI内容需要自动更新(比如:依赖于用户行为的改变或者外部的数据源发生变化),KO都可以很简单的帮你实现,并且非常易于维护。

       如何使用Knockout

      简单来说在knockoutjs中,每个HTML的DOM对象都是通过data-bind属性来绑定数据的。首先你需要把knockoutjs添加到页面中或者模板中,开始使用ko,首先你需要定义一个viewmodel;

      <script>

        var ViewModel ={

            firstName = ko.observable(first);
            lastName = ko.observable(last);
        };
        ko.applyBindings(ViewModel)

      </script>

      接下来需要做的是,把viewmodel的firstName和lastName两个属性绑定到HTML的DOM对象。

      如果是使用input来绑定:

      <p>First name: <input data-bind="value: firstName" /></p>

      <p>Last name: <input data-bind="value: lastName" /></p>

      如果是使用span来绑定:

      <p>First name: <input data-bind="text: firstName" /></p>

      <p>Last name: <input data-bind="text: lastName" /></p>
     
      运行结果:
      
      因为ko是MVVM模式,所以当任何绑定了某个属性的地方修改该属性值时,其它地方也会随之变化。就像上面的输入框”First name”变化为”你不好”时,那个span中得”你好”也会变为”你不好”

      knockoutjs是MVVM模式它的实现原理如下图:(发挥一下我设计的优势)

      

      KO和Jquery(prototype等)是相互竞争还是可以兼容一起使用?

      我个人比较喜欢用Jquery!对于各种不一致的DOM对象操作的API方法,Jquery的出现,很出色的代替了以往种种笨拙的框架,显得灵活易用。Jquery在Web页面元素操作和事件处理上显得相当出色并且易用,而KO是解决另外不同的问题的。

      当你的UI界面稍微复杂且含有一些相同的行为的话,如果你仅仅只使用Jquery,那么UI处理上会比你想象的要复杂棘手,同时会让维护费用相当昂贵。思考这样一个例子:在一个表格里显示一个项目列表,统计表格中列表的数量,当项目列表数量小于5时启用“Add”按钮,否则就禁用。Jquery没有基本的数据模型概念,所以你想要获取项目列表的数量,你需要从表格table/tr/div这些数量上去进行推断才能知道。如果需要在某些SPAN里显示数据的数量,当添加新数据的时候,你还要记得更新这个SPAN的text。当然,你还要记住当总数>=5条的时候,你需要禁用Add按钮。然后,如果还要实现Delete功能的时候,你不得不指出哪一个DOM元素被点击以后需要改变。

      而使用用Knockout来实现

      就会变成非常简单。它可以让你很轻易的扩展项目的复杂度,而不必担心由此产生的数据不一致问题。它仅仅只需要将你的数据转换成一个JavaScript数组,然后使用foreach将数据数组绑定到页面中的一个表格table或者一组div中。每当数据数组发生变化时,UI界面会自动响应改变(你不需要指出如何插入新行或在哪里插入),剩下的就是UI界面数据同步了。

      当然ko的知识还有很多,各种绑定事件,在接下来,我会不断总结。

  • 相关阅读:
    C++程序设计第二周作业
    navicat 连接windows服务器中的mysql数据库
    Python 多进程(二度回顾)
    MySQl 合并结构相同的多张表
    Python 验证码识别-- tesserocr
    Navicat Premium 修改MySQL密码(忘记密码的情况下)
    Navicat Premium 出现2059错误解决办法
    MySQL 1053错误 服务无法正常启动的解决方法
    mysql触发器trigger 实例详解
    navicat for mysql 连接报错1251详细解决步骤
  • 原文地址:https://www.cnblogs.com/sun927/p/5647660.html
Copyright © 2011-2022 走看看