时间:2021-05-26
if绑定目的
if绑定一般是格式是data-bind=if:attribute,if后所跟属性或表达式的值应为bool值(也可以是非bool值,当非空字符串时则为真),if绑定的作用与visible绑定的作用类似。可控制DOM的显示与隐藏,不一样的地方是,if绑定是物理删除或添加DOM元素。
示例1
该例展示IF绑定的动态删除添加DOM:
Display message
UI源码:
<label><input type="checkbox" data-bind="checked: displayMessage" /> Display message</label><div data-bind="if: displayMessage">Here is a message. Astonishing.</div>视图模型源码:
ko.applyBindings({displayMessage: ko.observable(false)});示例2
该示例中,通过foreach绑定循环planets监控属性数组,其中name为Mercury的项目中capital为null,则循环中该项目只显示其name.
<ul data-bind="foreach: planets"><li>Planet: <b data-bind="text: name"> </b><div data-bind="if: capital">Capital: <b data-bind="text: capital.cityName"> </b></div></li></ul><script>ko.applyBindings({planets: [{ name: 'Mercury', capital: null }, { name: 'Earth', capital: { cityName: 'Barnsley' } } ]});</script>备注:使用无容器的if绑定(if虚拟绑定)
像之前的虚拟绑定一样,同样使用<!-- ko -->和<!-- /ko -->进行。虚拟绑定适用于不改变UI元素的情况。
<ul><li>This item always appears</li><!-- ko if: someExpressionGoesHere --><li>I want to make this item present/absent dynamically</li><!-- /ko --></ul>ifnot绑定
ifnot绑定是if绑定的逆向表达,格式与if绑定一样,只是判断结果与if整好相反。就像等于和不等于一样。例如:
<div data-bind="ifnot: someProperty">...</div>其等效写法为:
<div data-bind="if: !someProperty()">...</div>有人会说使用if绑定是足够了。为毛还要ifnot绑定。原因是有很多强迫症患者喜欢这种ifnot的绑定方式,看起来更易懂,代码更整洁。
以上所述是小编给大家介绍的KnockoutJS 3.X API 第四章之数据控制流if绑定和ifnot绑定,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
第四章XML语法提纲:一.XML语法规则二.元素的语法三.注释的语法四.CDATA的语法五.Namespaces的语法六.entity的语法七.DTD的语法通过
《外贸来函电》这门课程有十一章自内容,包括:bai第一章商务信函的格式、du第二章商务信函的写作原则、第三章建立dao业务关系、第四章询盘、第五章报盘、第六章C
1、前言工作中涉及到文件系统,有时候需要判断文件和目录是否存在。我结合APUE第四章文件和目录,总结一下如何正确判断文件和目录是否存在,方便以后查询。2、sta
各位抖音达人注意,抖音内容电商禁售类目规范调整了,其中第三章违规处理及附则有变化,具体的变化看下面。变更1变化前:变化后:变更2变化前:变化后:第四章附则第十一
各位亲爱的会员:闲置商品交易较为特殊,其交易纠纷的处理也存在特殊性,此次将在《淘宝争议处理规则》“第四章特殊交易争议处理规范”中新增关于闲鱼(闲置)市场的争议处