Knockout JS 增加、去除、修改绑定
Knockuot js 似乎只考虑过怎么绑定(ko.applyBindings()),却没考虑过怎么去除绑定,当修改了DOM内容,需要重新绑定时,发现似乎无能为力。
一、解决办法
这里有一个重新绑定的方法,就是使用ko.cleanNode(<YOUR DOM NODE>),然后再使用ko.applyBindings()重新绑定就可以了。
1、VIEW模型
- <h3>3、更改绑定</h3>
- <div id="divSample3">
- 你叫啥?<span id='span3' data-bind='text: name'></span><br/>
- <a href="javascript:void(0)" onclick="updateBingding()">我问的是别名!</a>
- </div>
2、VIEW-MODEL
- <script type="text/javascript">
- var viewModel = function () {
- this.name = ko.observable("张三");
- this.aliasName = ko.observable("三儿");
- };
- //var myModel = new viewModel();
- ko.applyBindings(new viewModel(),document.getElementById('divSample3'));
- var viewModel2 = function () {
- this.name = ko.observable("张三");
- this.aliasName = ko.observable("三儿");
- };
- //更改绑定
- function updateBingding(){
- //$("#span3").attr("data-bind", "text: aliasName"); //使用jQuery
- var span3 = document.getElementById('span3'); //不使用jQuery
- span3.setAttribute("data-bind", "text:aliasName");
- ko.cleanNode(span3);
- ko.applyBindings( new viewModel2(), span3);
- }
- </script>
二、问题
1、但是据说这样可能存在问题,问题之一是与DOM相关的事件绑定是没法去除的。
这里提供一个外国哥们使用的方法:
- <script lang="javascript">
- ko.unapplyBindings = function ($node, remove) {
- // unbind events
- $node.find("*").each(function(){
- $(this).unbind();
- });
- // Remove KO subscriptions and references
- if(remove) {
- ko.removeNode($node[0]);
- } else {
- ko.cleanNode($node[0]);
- }
- };
- </script>
这个方法使用jQuery方法在取消绑定前,去除绑定的事件,然后再清除缓存的绑定配置,同时具有一定的通用性。
但这个方法应只对jQuery的事件绑定有效,如果使用其他方式绑定的事件,可能去除不彻底。
2、建议尽量使用if或with绑定来控制,使用下面的形式来操作,灵活性肯定不如直接使用JavaScript操作方便。
<!-- ko if: editortype == 'checkbox' -->\
...
<!-- /ko -->\
三、增加和移除绑定
增加绑定即动态增加一个DOM节点,然后再绑定该DOM节点。移除绑定即将DOM节点原有的绑定给去除,不让绑定操作再生效。
1、增加绑定
VIEW模型:
- <h3>1、动态添加绑定</h3>
- <div id="divSample1">
- <a href="javascript:void(0)" onclick="add_Binding()">添加绑定</a>
- </div>
VM模型:
- <script type="text/javascript">
- var viewModel = function () {
- };
- var myModel = new viewModel();
- //添加绑定
- function add_Binding(){
- //viewModel添加属性
- myModel.des = ko.observable("this is a demo");
- //添加绑定元素
- var html = "<span id='add_banding' data-bind='html: des'></span>";
- document.body.innerHTML = document.body.innerHTML + html;
- var add = document.getElementById("add_banding");
- ko.applyBindings(myModel, add);
- }
- </script>
2、去除绑定
VIEW模型:
- <h3>2、移除绑定</h3>
- <div id="divSample2">
- 原始值:<span id='span1' data-bind='text: des'></span><br/>
- 对照值:<span id='span2' data-bind='text: des'></span><br/>
- <a href="javascript:void(0)" onclick="changeModelValue()">改变model属性值</a>
- <a href="javascript:void(0)" onclick="removeBingding()">去除"对照值"的绑定</a>
- </div>
VM模型:
- <script type="text/javascript">
- var viewModel = function () {
- this.des = ko.observable("this is a demo");
- };
- var myModel = new viewModel();
- ko.applyBindings(myModel, document.getElementById("divSample2"));
- //改变des值
- function changeModelValue(){
- myModel.des(new Date().valueOf());
- }
- //移除绑定
- function removeBingding(){
- var span2 = document.getElementById("span2");
- alert(span2.getAttribute('data-bind'));
- span2.setAttribute("data-bind", "");
- alert(span2.getAttribute('data-bind'));
- ko.cleanNode(span2);
- ko.applyBindings(myModel, span2);
- }
- </script>
说明:此例参照了网上一位兄弟的示例,其思路比较清晰,但其提供的示例并没有真正解决多次绑定的问题,向这位兄弟表示感谢。
参考:
1、How to clear/remove observable bindings in Knockout.js?
Knockout JS 增加、去除、修改绑定的更多相关文章
- 一个简单的knockout.js 和easyui的绑定
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>Basi ...
- Knockout.js(四):自定义绑定
除了内嵌的绑定,还可以创建一些自定义绑定,封装复杂的逻辑或行为. 注册绑定 添加子属性到ko.bindingHandlers来注册绑定: ko.bindingHandlers.yourBindingN ...
- 【Knockout.js 学习体验之旅】(3)模板绑定
本文是[Knockout.js 学习体验之旅]系列文章的第3篇,所有demo均基于目前knockout.js的最新版本(3.4.0).小茄才识有限,文中若有不当之处,还望大家指出. 目录: [Knoc ...
- 4.Knockout.Js(事件绑定)
前言 click绑定在DOM元素上添加事件句柄以便元素被点击的时候执行定义的JavaScript 函数.大部分是用在button,input和连接a上,但是可以在任意元素上使用. 简单示例 <h ...
- knockout更新列表中的某条数据,knockout.js绑定数组时更新其中一条数据
knockout是一款前端实现MVVM的JS框架,仅knockout.js一个47kb的文件,相当实用,做前端无刷新页面,快速实现JS与HTML数据交互. knockout目前最新版:knockout ...
- knockout.js模板绑定之利用Underscore.js模板引擎示例
View代码 <h1>People</h1> <ul data-bind="template: { name: 'peopleList' }"> ...
- Knockout.js随手记(3)
下拉菜单 <select>也是网页设计重要的一环,knockout.js(以下简称KO)也有不错的支持.针对<select>,在data-bind除了用value可对应下拉菜单 ...
- MVC3.0+knockout.js+Ajax 实现简单的增删改查
MVC3.0+knockout.js+Ajax 实现简单的增删改查 自从到北京入职以来就再也没有接触MVC,很多都已经淡忘了,最近一直在看knockout.js 和webAPI,本来打算采用MVC+k ...
- MVC中利用knockout.js实现动态uniqueId
题目比较拗口,但是这篇文章确实直说这一点. knockout.js是一个JS库,它的官网是http://knockoutjs.com/ 这篇文章的重点是knockout在工作的一个功能中的应用.最终效 ...
随机推荐
- 深入理解Java Callable接口
概述Callable和Runnbale一样代表着任务,区别在于Callable有返回值并且可以抛出异常.其使用如下: public class CallableDemo { static class ...
- 如何用 Java 实现 Web 应用中的定时任务?
定时任务,是指定一个未来的时间范围执行一定任务的功能.在当前WEB应用中,多数应用都具备任务调度功能,针对不同的语音,不同的操作系统, 都有其自己的语法及解决方案,windows操作系统把它叫做任务计 ...
- Spring RestTemplate中几种常见的请求方式GET请求 POST请求 PUT请求 DELETE请求
Spring RestTemplate中几种常见的请求方式 原文地址: https://blog.csdn.net/u012702547/article/details/77917939 版权声明 ...
- 哈,今天终于在电脑上吧oracle给装上了
哈,今天终于在电脑上吧oracle给装上了
- C# 图片识别(支持21种语言) (转)
图片识别的技术到几天已经很成熟了,只是相关的资料很少,为了方便在此汇总一下(C#实现),方便需要的朋友查阅,也给自己做个记号. 图片识别的用途:很多人用它去破解网站的验证码,用于达到自动刷票或者是批量 ...
- [leetcode]Interleaving String @ Python
原题地址:https://oj.leetcode.com/problems/interleaving-string/ 题意: Given s1, s2, s3, find whether s3 is ...
- 在Cygwin里,如何进入到C盘?
答: cd /cygdrive/c 来源: How to navigate to a directory in C:\ with Cygwin? https://stackoverflow.com/q ...
- Twitter雪花算法 SnowFlake算法 的java实现
概述 SnowFlake算法是Twitter设计的一个可以在分布式系统中生成唯一的ID的算法,它可以满足Twitter每秒上万条消息ID分配的请求,这些消息ID是唯一的且有大致的递增顺序. 原理 Sn ...
- 网站设计之合理架构CSS
架构CSS 在当前浏览器普遍支持的前提下,css被我们赋予了前所未有的使命.然而依赖css越多,样式表文件就会变得越大越复杂.与此同时,文件维护和组织的考验也随之而来. (曾几何时)只要一个css文件 ...
- Qt OpenGL:学习现代3D图形编程之四,透视投影浅析
一.非真实的世界 与之前几篇文章不同的是,这里要画12个三角形,这个12个三角形构造一个方形棱柱(这里为长方体).棱柱的每个四边形表面由两个三角形组成.这两个三角形其中的一条边重合,而且它们的六个顶点 ...