WeX5数据绑定:if绑定和ifnot绑定

优质
小牛编辑
142浏览
2023-12-01

if绑定

if绑定应用在页面元素中,并通过表达式判断是否为元素添加子元素的绑定。if绑定在功能上非常像visible绑定,但在实现上却有很大的不同。visible绑定是为元素添加css样式来控制元素是否显示,if绑定是控制元素的字元素,如果表达式为true,则为元素添加子元素,否则清空子元素。

示例代码:

//.W片段
<label>
 <input type="checkbox" bind-checked="displayMessage" />
 Display message
</label>
<div bind-if="displayMessage">Here is a message. Astonishing.</div>

//.js片段
displayMessage=justep.Bind.observable(false);

当displayMessage为false的时候,div将会被清空;如果为true的时候,div里面的内容才会被添加到dom中显示。

ifnot绑定

ifnot绑定与if的功能相反,当表达式为true的时候,元素的内容会被清空,如果为false的时候,元素的内容会被添加到DOM中。

我们把上面的示例代码改成ifnot绑定:

//.W片段
<label>
 <input type="checkbox" bind-checked="displayMessage" />
 隐藏消息
</label>
<div bind-ifnot="displayMessage">Here is a message. Astonishing.</div>

//.js片段
displayMessage=justep.Bind.observable(false);

看看是不是与if相反呢?

其实,我们可以使用if绑定来实现ifnot的功能:

//.W片段
<label>
 <input type="checkbox" bind-checked="displayMessage" />
 隐藏消息
</label>
<div bind-if="!displayMessage">Here is a message. Astonishing.</div>

//.js片段
displayMessage=justep.Bind.observable(false);

另外,if绑定和ifnot绑定都可以使用虚拟节点来完成绑定:

<ul>
    <li>This item always appears</li>
    <li>I want to make this item present/absent dynamically</li>
</ul>

虚拟节点在这种情况下非常有用。