knockoutJS学习笔记05:控制文本和外观绑定

测试数据:

    function Person(name,age){
        var self = this;
        self.name = ko.observable(name);
        self.age = ko.observable(age);
        self.isShow = ko.observable("");
        self.html = "<div>没有div</div>",
        self.isRed = true
    }
    var person = new Person("tom",18);
    ko.applyBindings(person);

 一、text 绑定

  例如div、span 等标签的文本显示,text绑定是经过html编码的。

    <div data-bind="text:name"></div>
    <span data-bind="text:18"></span>

 二、visible 绑定

  如果变量或表达式为真,则正常显示;否则设置:display:none。  

    <div style="color:red;" data-bind="visible:isShow">显示或不显示</div>
    <div style="color:red;" data-bind="visible:age() >= 18">成年或未成年</div>

  这里有一个小小的建议,js中,为假的情况有:布尔类型的:false、数字类型的:0 、字符类型的:"", 还有 null 和 undifined。有时候看到有些人这样写:if(str != null && str != ""){...},其实可以简写为:if(str){...}

三、html 绑定

  设置元素的innerHTML属性,不会对绑定内容进行html编码,所以可以引起html攻击。所以需要自己进行编码,或者改用text绑定。  

<div data-bind="html:html"></div>

 四、attr绑定

  attr可以设置html元素的基本属性,例如img 的 src 属性,a 的href 属性等。attr 属性是一个对象,可以设置多个绑定属性。

    <a data-bind="attr:{href:‘default.aspx?name=‘+name(),title:name},text:name"></a>

 五、style 绑定

  style绑定用于设置dom元素的样式,根据变量或表达式的真/假,设置或移除样式。如果样式比较复杂的,建议用css绑定。

<div data-bind="style:{color:isRed ? ‘red‘ : ‘yellow‘ }">style绑定</div>

 六、css 绑定

  css根据变量或表达式的真假,添加class属性到dom元素。  

<div data-bind="css:{red: isRed}">css绑定</div>

七、总结

  可以看到,ko除了可以用于数据绑定,还可以用于样式绑定。总之就是让我们尽量减少操作dom。上面还没有提到表单域的相关绑定,会在后面说明。

时间: 2024-08-06 20:01:24

knockoutJS学习笔记05:控制文本和外观绑定的相关文章

KnockoutJS(4)-控制文本和外观绑定

控制文本和外观绑定 依赖关系:除了Knockout核心库之外,无依赖关系. 类别 目的 Visible绑定 Visible绑定通过绑定一个值来确定DOM元素显示或隐藏 Text绑定 Text绑定主要是让DOM元素显示参数值. 通常情况下,该绑定在<span>和<em>这样的元素上非常有用,而实际上你可以绑定任何元素. html 绑定 html绑定到DOM元素上,使得该元素显示的HTML值为你绑定的参数.如果在你的view model里声明HTML标记并且render的话,那非常有用

knockoutJS学习笔记08:表单域绑定

前面的绑定都是用在基本标签上,这章主要讲表单域标签的绑定. 一.value 绑定 绑定标签:input text.textarea. <p>用户名:<input type="text" data-bind="value:name" /><span data-bind="text:name"></span></p> <p>密码:<input type="text

Knockout学习之文本和外观绑定器

文本和外观绑定器 “visible”绑定 该绑定主要用来让我们通过监控属性可以控制html文档的显示,只要绑定的监控属性为false.0.null或者undefined则隐藏该标签,否则显示.比如下面的示例: 1 <span data-bind="visible:visibleState">显示了</span> 2 <div> 3 <button type="button" data-bind="click:sho

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

SWIFT学习笔记05

1.Swift 无需写break,所以不会发生这种贯穿(fallthrough)的情况.2.//用不到变量名,可用"_"替换 for _ in 1...power { answer *= base } 3.case 可以匹配更多的类型模式,包括区间匹配(range matching),元组(tuple)和特定类型的描述. 可以这样用case case 1...3: naturalCount = "a few" 4.如果存在多个匹配,那么只会执行第一个被匹配到的 ca

STM8S学习笔记-时钟控制1

1.图13可见,STM8S单片机主要有四种时钟源可供选择: 1).1-24MHz外部晶体振荡器(HSE). 2).最大24MHz外部时钟(HSE ext). 3).16MHz高速内部RC振荡器(HSI). 4).128KHz低速内部RC振荡器(LSI). 2.主时钟可以从这四种时钟源中任意切换,切换过程可通过自动切换和手动切换. 自动切换过程: CLK_SWCR |= 0x20;    //使能切换 CLK_SWR = 0xE1; //  (HSI----复位值) // (0xD2 ----LS

CSS学习笔记:溢出文本省略(text-overflow)

原文:CSS学习笔记:溢出文本省略(text-overflow) 在CSS3中,text-overflow属性的基本语法如下: clip:表示不显示省略文本,简单的裁切. ellipsis:表示对象文本溢出时显示省略标记,省略标记插入的位置是最后一个字符. ellipsis-word:表示当对象文本溢出时显示省略标记,省略标记插入的位置是最后一个词(word). 实际上,text-overflow属性仅用于决定当文本溢出时是否显示省略标记,并不具备样式定义的功能,要实现溢出时产生省略号的效果,应

C++ GUI Qt4学习笔记05

C++ GUI Qt4学习笔记05 qtc++正则表达式 QIntValidator           --  只让用户输入整数 QDoubleValidator     --  只让用户输入浮点数 QRegExpValidator    --  只让用户按照正则表达式定义好的样式进行输入 本章讲解如何使用Qt开发自定义窗口部件. 通过对一个已经存在的Qt窗口部件进行子类化或者直接对QWidget进行子类化,就可以创建自定义窗口部件. 集成自定义窗口到Qt设计师中,这样就可以像使用内置的Qt窗

STM8S学习笔记-时钟控制2

今天把时钟系统的最后部分,时钟安全系统(CSS)和时钟输出功能(CCO),做一个简答的说明. 1.时钟安全系统(以下简称CSS) CSS功能很简单,就是监控HSE是否实效(如果系统使用HSE作为主时钟源),而自动切换到HSI/8作为主时钟源,从而避免系统停止运行. 如果使能CSSIEN,当主时钟失效,切换到HSI/8后可产生一个中断,这时可以改变HSI的分频,从而系统继续正常工作. 如果系统主时钟源不是HSE,则不用关心CSS. 2.时钟输出功能(以下简称CCO) CCO是MCU向外提供系统时钟