• KnockoutJS 3.X API 第四章 数据绑定(1) 文本及样式绑定


    目录

    本节将介绍六种文本绑定方式:

    1. visible绑定
    2. text绑定
    3. html绑定
    4. css绑定
    5. style绑定
    6. attr绑定

    可见文本绑定(visible)

    使用visible绑定,来控制DOM元素的可见或隐藏

    例子:

    <div data-bind="visible: shouldShowMessage">
        You will see this message only when "shouldShowMessage" holds a true value.
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            shouldShowMessage: ko.observable(true) // Message initially visible
        };
        viewModel.shouldShowMessage(false); // ... now it's hidden
        viewModel.shouldShowMessage(true); // ... now it's visible again
    </script>

    参数:

    • 主要技术参数

      • 当参数解析为(例如,布尔值false,或数字值0,或者null,或undefined),则当前元素隐藏,如同CSS样式中display:none。

      • 当参数解析为(例如,布尔值true,或者一个非null对象或序列)中,使其成为可见的。

    使用函数和表达式来控制元素的可见性

    您还可以使用JavaScript函数或任意JavaScript表达式作为参数值,KO将运行你的函数/表达式,并使用结果来确定是否隐藏元素。

    例如:

    <div data-bind="visible: myValues().length > 0">
        You will see this message only when 'myValues' has at least one member.
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            myValues: ko.observableArray([]) // Initially empty, so message hidden
        };
        viewModel.myValues.push("some value"); // Now visible
    </script>

    文本绑定(text)

    使用text绑定到相关的DOM,以显示视图模型属性的值。可用于任何DOM元素上

    例如:

    Today's message is: <span data-bind="text: myMessage"></span>
     
    <script type="text/javascript">
        var viewModel = {
            myMessage: ko.observable() // Initially blank
        };
        viewModel.myMessage("Hello, world!"); // Text appears
    </script>
     

    使用函数和表达式来作为文本值

    例如:

    The item is <span data-bind="text: priceRating"></span> today.
     
    <script type="text/javascript">
        var viewModel = {
            price: ko.observable(24.95)
        };
        viewModel.priceRating = ko.pureComputed(function() {
            return this.price() > 50 ? "expensive" : "affordable";
        }, viewModel);
    </script>

    也可以写为如下等同格式:

    The item is <span data-bind="text: price() > 50 ? 'expensive' : 'affordable'"></span> today.

    HTML编码

    在给视图属性赋值时,默认KO时进行HTML编码的,也就是说,如果赋值的是带有DOM标记或者JS脚本的值,一律会原封不动的显示。不会造成安全隐患或脚本注入等情况。

    例如:

    viewModel.myMessage("<i>Hello, world!</i>");

    只会显示<i>Hello,workld!</i>,而不是斜体文本hello world

    使用无容器的text绑定

    在某些情况下,可能不允许在UI中加入新的dom元素作为KO的text绑定容器,比如下边的这个例子,如果在option元素中再加入新的span元素,将导致无法正常工作:

    <select data-bind="foreach: items">
        <option>Item <span data-bind="text: name"></span></option>
    </select>

    在这种情况中,可以使用ko自带的无容器绑定写法<!--ko--><!--/ko-->,使用这种写法,ko会虚拟出一个容器元素作为绑定使用。

    <select data-bind="foreach: items">
        <option>Item <!--ko text: name--><!--/ko--></option>
    </select>

    HTML绑定

    次绑定方式主要用于显示HTML相关的DOM元素,具体的讲就是将包含HTML元素的视图模型属性渲染到UI上。例如:

    <div data-bind="html: details"></div>
     
    <script type="text/javascript">
        var viewModel = {
            details: ko.observable() // Initially blank
        };
        viewModel.details("<em>For further details, view the report <a href='report.html'>here</a>.</em>"); // HTML content appears
    </script>

    这种方式要注意的是脚本注入攻击,切勿将该方式用于用户输入。

    CSS绑定

    目的:

    CSS绑定主要用于对DOM元素的CSS类添加或删除,这种方式是很有用的,当然Jquery也能做到这一点。

    静态例子:

    <div data-bind="css: { profitWarning: currentProfit() < 0 }">
       Profit Information
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            currentProfit: ko.observable(150000) // Positive value, so initially we don't apply the "profitWarning" class
        };
        viewModel.currentProfit(-50); // Causes the "profitWarning" class to be applied
    </script>

    上述例子意思是,当视图属性currentProfit小于0时,将移除div元素的profitWarning的css类。

    动态例子:

    <div data-bind="css: profitStatus">
       Profit Information
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            currentProfit: ko.observable(150000)
        };
     
        // Evalutes to a positive value, so initially we apply the "profitPositive" class
        viewModel.profitStatus = ko.pureComputed(function() {
            return this.currentProfit() < 0 ? "profitWarning" : "profitPositive";
        }, viewModel);
     
        // Causes the "profitPositive" class to be removed and "profitWarning" class to be added
        viewModel.currentProfit(-50);
    </script>

    上述例子的意思是,当currentProfit视图属性值小于0时,div元素的添加css类profitWarning,否则添加css类profitPositive。

    注意:

    你可以设置一个或多个CSS绑定,来实现多个绑定需求:

    <div data-bind="css: { profitWarning: currentProfit() < 0, majorHighlight: isSevere }">

    你甚至也可以用引号把CSS类名括起来:

    <div data-bind="css: { profitWarning: currentProfit() < 0, 'major highlight': isSevere }">

    在视图模型属性返回值中,0null被视为false,非null或非零的值被视为true

    如果视图模型属性是一个监控属性类型(observable),那么之后的css绑定将根据模型属性的值变化而变化,如果你的视图模型属性不是一个监控属性,那只有第一次运行会变化,之后将不会改变。在动态CSS绑定中同样适用该规则。

    二次注意:

    如果你要添加的CSS类名是my-class,如果你像下边这种写法的话,将没有效果

    <div data-bind="css: { my-class: someValue }">...</div>

    因为my-class这种名字是不合法的在KO的CSS绑定中,解决这个问题最简单的方法是加上引号:

    <div data-bind="css: { 'my-class': someValue }">...</div>

    Style绑定

    目的:

    style绑定与CSS绑定类似,只是style绑定是添加或删除一个或多个元素样式,例如:

    <div data-bind="style: { color: currentProfit() < 0 ? 'red' : 'black' }">
       Profit Information
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            currentProfit: ko.observable(150000) // Positive value, so initially black
        };
        viewModel.currentProfit(-50); // Causes the DIV's contents to go red
    </script>

    上述例子是将div元素的color样式赋值,当currentProfit视图模型属性的值小于0时,赋值red,否则赋值black;

    与CSS绑定一样,style绑定也支持多个参数同时绑定。比如:

    <div data-bind="style: { color: currentProfit() < 0 ? 'red' : 'black', fontWeight: isSevere() ? 'bold' : '' }">...</div>

    如果视图模型属性是一个监控属性类型(observable),那么之后的style绑定将根据模型属性的值变化而变化,如果你的视图模型属性不是一个监控属性,那只有第一次运行会变化,之后将不会改变。

    注意:

    如果你需要绑定一些style,例如font-weight或者text-decoration

    • 不要写成这样 { font-weight: someValue }; 要写成这样{ fontWeight: someValue }
    • 不要写成这样 { text-decoration: someValue }; 要写成这样{ textDecoration: someValue }

    更多的Style绑定的KO写法请点击这个地址查看

    attr绑定

    目的:

    attr绑定主要是为了通过KO设置元素的值,比如img标签的src值,a标签的href值和title值。例如:

    <a data-bind="attr: { href: url, title: details }">
        Report
    </a>
     
    <script type="text/javascript">
        var viewModel = {
            url: ko.observable("year-end.html"),
            details: ko.observable("Report including final year-end statistics")
        };
    </script>

    上述例子将设置DOM上a标签的href为year-end.html,设置a标签的title为Report including final year-end statistics。

    注意:

    如果你像更改元素的data-something属性的值时,不可以写成下main这样:

    <div data-bind="attr: { data-something: someValue }">...</div>

    因为data-something是KO中不合法的标识名称。最简单的方法是用引号括住:

    <div data-bind="attr: { 'data-something': someValue }">...</div>
  • 相关阅读:
    Conda 中安装 Keras
    Clean Docker :
    Conservation Vs Non-conservation Forms of conservation Equations
    C语言之预处理命令
    const指针用法总结
    C语言中的小启发(陆续更新。。。)
    左值与右值
    计算的次序
    C语言中的符号重载
    C语言之switch语句详解
  • 原文地址:https://www.cnblogs.com/smallprogram/p/5929491.html
Copyright © 2020-2023  润新知