Knockout学习之文本和外观绑定器
文本和外观绑定器
“visible”绑定
该绑定主要用来让我们通过监控属性可以控制html文档的显示,只要绑定的监控属性为false、0、null或者undefined则隐藏该标签,否则显示。比如下面的示例:
<span data-bind="visible:visibleState">显示了</span>
<div>
<button type="button" data-bind="click:show">出现吧,我的皮卡丘</button>
<button type="button" data-bind="click:hide">滚粗吧,你!</button>
</div> <script type="text/javascript"> var appViewModel = function () {
this.visibleState = ko.observable(false);
this.show = function () {
this.visibleState(true);
};
this.hide = function () {
this.visibleState(false);
}
} ko.applyBindings(new appViewModel());
</script>
默认是不显示的,当点击出现按钮设置visibleState的值为true,因为ko会自动更新。所以对应的标签也就显示了,相反我们点击另一个按钮,则标签消失。这仅仅只是通过监控属性来控制,我们也可以使用表达式,我们将上面的代码改写:
<span data-bind="visible:visibleState() == true">显示了</span>
我们直接在data-bind中写了判断语句,当然这是可以的。最后效果还是跟之前的一样。
“text”绑定
前面我们一直在使用这个绑定,所以这里笔者就不把那些重复的东西继续介绍了,直接介绍我们没有使用过的语法,在前面的使用过程中我们一直都是直接将监控属性显示到对应标签中,其实我们可以在标签文本的指定位置显示,比如下面的代码:
<ul data-bind="foreach:datalist" >
<li>value<!--ko text:value--><!--/ko--></li>
</ul> <script type="text/javascript"> var appViewModel = function () {
this.datalist = ko.observableArray([{ "value": 1 }, { "value": 2 }, { "value": 3 }]);
} ko.applyBindings(new appViewModel());
</script>
我们将可以看到如下的结果:

“html”绑定
其实这个绑定跟text差不多,都是设置标签的内容,但是如果我们的监控属性中存在标签,则就存在意义了,因为text会将我们的标签转义输出,而html则不会,比如下面的示例:
<div data-bind="html: htmlText" >
</div>
<script type="text/javascript">
var appViewModel = function () {
this.htmlText = ko.observable("<h1>哈哈,我们又见面了</h1>");
}
ko.applyBindings(new appViewModel());
</script>
最终的效果图如下所示:

“css”绑定
其实这个属性一开始我会认为可以设置style,其实不相干,它只是用来控制class使用哪些样式的,第一种方式是直接通过监控属性赋样式,比如下面这种方式:
<style type="text/css">
.test1 {
background-color: red;
} .test2 {
background-color: green;
}
</style> <div data-bind="css: cssName">
我会变色
</div>
<div>
<button type="button" data-bind="click: changeTest1">我变</button>
<button type="button" data-bind="click: changeTest2">我再变</button>
</div> <script type="text/javascript"> var appViewModel = function () {
this.cssName = ko.observable("");
this.changeTest1 = function () {
this.cssName("test1");
};
this.changeTest2 = function () {
this.cssName("test2");
};
} ko.applyBindings(new appViewModel());
</script>
一开始默认是没有颜色的,当我们点击不同的按钮后可以看到这个div会切换不同的背景色,这些都是通过ko来实现的,当然我们也可以不用这种方式,而是通过表达式去控制,比如下面这种方式:
<div data-bind="css:{ test1:cssName() == 'test1',test2:cssName() == 'test2'}">
我会变色
</div>
虽然换成了表达式的形式,但是最终的效果跟上面的是完全一样的,读者可以根据自己的实际情况来选择。
“style”绑定
这个属性必须是控制style的了,这里我们将上面的示例改写:
<div data-bind="style: { backgroundColor: cssName() }">
我会变色
</div>
<div>
<button type="button" data-bind="click: changeTest1">我变</button>
<button type="button" data-bind="click: changeTest2">我再变</button>
</div>
<script type="text/javascript">
var appViewModel = function () {
this.cssName = ko.observable("");
this.changeTest1 = function () {
this.cssName("red");
};
this.changeTest2 = function () {
this.cssName("green");
};
}
ko.applyBindings(new appViewModel());
</script>
“attr”绑定
有了这个就可以尽情的修改标签中的任何属性了,笔者再次就举一个关于切换a标签的href值,代码如下:
<a data-bind="attr:{href:doHref}">快点我</a>
<div>
<button type="button" data-bind="click:changeTest1">换地址1</button>
<button type="button" data-bind="click:changeTest2">换地址2</button>
</div>
<script type="text/javascript">
var appViewModel = function () {
this.doHref = ko.observable("");
this.changeTest1 = function () {
this.doHref("http://www.baidu.com");
};
this.changeTest2 = function () {
this.doHref("http://www.cnblogs.com/");
};
}
ko.applyBindings(new appViewModel());
</script>
具体效果,copy代码走一遍就知道了。
Knockout学习之文本和外观绑定器的更多相关文章
- KnockoutJS(4)-控制文本和外观绑定
控制文本和外观绑定 依赖关系:除了Knockout核心库之外,无依赖关系. 类别 目的 Visible绑定 Visible绑定通过绑定一个值来确定DOM元素显示或隐藏 Text绑定 Text绑定主要是 ...
- (二)Knockout 文本与外观绑定
Visible Visible binding会依据绑定的数据来决定相应的DOM元素是否隐藏,hidden或visible. 我们首先在js文件部分定义一个view model,这里我创建的是一个ob ...
- knockoutJS学习笔记05:控制文本和外观绑定
测试数据: function Person(name,age){ var self = this; self.name = ko.observable(name); self.age = ko.obs ...
- knockout学习笔记目录
关于knockout学习系列的文章已经写完,这里主要是做个总结,并且将目录罗列出来,方便查看.欢迎各位大神拍砖和讨论. 总结 kncokout是一个轻量级的UI类库,通过MVVM模式使前端的UI简单话 ...
- Knockout学习之模板绑定器
模板绑定器 如今页面结构越来越复杂,仅仅依靠foreach已经不足以我们的使用,这个时候我们就需要模板的存在,模板的优点自然很多,首先会让页面整洁,同时修改起来也可以方面的定位,最重要的是ko可以条件 ...
- Knockout学习之表单绑定器(下)
“hasFocus”绑定 hasFocus绑定器会将DOM元素的焦点状态与视图模型中的属性相关联,当你设置视图模型中关联的属性为true或false后,将能够设置关键的DOM元素是否获得焦点. 比如下 ...
- Knockout学习之表单绑定器(上)
表单绑定器 “click”绑定 Click 绑定器可以将javascript函数绑定到指定的dom元素,并且再该元素被点击时将触发绑定的函数,大多数情况下都会使用button.input和a元素,当然 ...
- Knockout学习之控制流绑定器
控制流绑定器 “foreach”绑定 顾名思义,通过该绑定我们就可以将监控数组循环输出到页面中去了,当然我们还是先来段简单的示例,仅仅只是输出监控数组: <ul data-bind=" ...
- C++11 学习笔记 std::function和bind绑定器
C++11 学习笔记 std::function和bind绑定器 一.std::function C++中的可调用对象虽然具有比较统一操作形式(除了类成员指针之外,都是后面加括号进行调用),但定义方法 ...
随机推荐
- 理解Java ThreadLocal
ThreadLocal是什么 早在JDK 1.2的版本中就提供Java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地 ...
- Photoshop 使用阈值调整色阶
1. 阈值原理 阈值的定义其实就是“临界点”,即过了这个临界点是一种情况(比如黑色),没有超过这个临界点是另外一种情况(比如白色),所以图像上只有黑.白两种情况出现.临界点的值由你定义: 阈值实际应用 ...
- Spring RestTemplate中几种常见的请求方式GET请求 POST请求 PUT请求 DELETE请求
Spring RestTemplate中几种常见的请求方式 原文地址: https://blog.csdn.net/u012702547/article/details/77917939 版权声明 ...
- Asp.netMVC中Html.Partial,RenderPartial,Action,RenderAction区别和用法
https://www.2cto.com/kf/201702/602449.html Partial 和RenderPartial: 这两个的性质都是一样, 只指把一个个View给镶入进来, 只是回传 ...
- 突发奇想之:源码及文档,文档包括源码---xml格式的源码,文档源码合并;注释文档化,文档代码化;
目前源码和文档一般都是分开的,我在想为什么 源码不就是最好的文档么? 但是一般源码都是文本text的,格式化需要人为统一规范,所以源码中的文档在现实中不是那么的易于实践. 而且 源码 不能包括图片.附 ...
- 分享一个Panda C-60 维修心得
昨天丰臣国际搞了个汽车后备箱市场,说白了就是一帮闲的没事儿的"白领"大热天把自家闲置的东西拿过来练练摊,这个形式还是不错的,中间看到了一个熊猫的CD机,一眼就看上了,虽说CD早就过 ...
- LeetCode295-Find Median from Data Stream && 480. 滑动窗口中位数
中位数是有序列表中间的数.如果列表长度是偶数,中位数则是中间两个数的平均值. 例如, [2,3,4] 的中位数是 3 [2,3] 的中位数是 (2 + 3) / 2 = 2.5 设计一个支持以下两种操 ...
- 构建-14 Gradle使用技巧
官方文档 Gradle 提示与诀窍 [Gradle tips and recipes] Gradle 和 Android Plugin for Gradle 提供了一种灵活的方式[a flexible ...
- jQuery中的编程范式
浏览器前端编程的面貌自2005年以来已经发生了深刻的变化,这并不简单的意味着出现了大量功能丰富的基础库,使得我们可以更加方便的编写业务代码,更重要的是我们看待前端技术的观念发生了重大转变,明确意识到了 ...
- 使用Java开发微信公众平台(二)——消息的接收与响应
上一篇文章(http://www.jerehedu.com/fenxiang/171807_for_detail.htm )中,我们学习了使用Java语言开发微信公众平台的第一部分——环境搭建与开发接 ...