WeX5数据绑定:value绑定

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

value绑定将ViewModel的参数绑定在form元素中,当form元素与ViewModel的属性建立关联之后,form元素的改变将会直接修改ViewModel的数据。

示例代码:

//.W片段
<p>Login name: <input bind-value="userName" /></p>
<p>Password: <input type="password" bind-value="userPassword" /></p>

//.js片段
//初始化空白块
this.userName=justep.Bind.observable(""); 

 this.userPassword=justep.Bind.observable("abc");

设置更新ViewModel的时间

在使用value绑定的时候,我们经常要将value绑定在input、textarea中。在默认情况下,当我们的input标签失去焦点的时候,才会触发ViewModel的改变。我们可以通过valueUpdate属性来控制何时来更新ViewModel。

  • input:这种事件需要现代浏览器的支持(IE9+),当input、textarea输入时改变ViewModel。如果不考虑浏览器兼容问题,这种方式将是最好的。
  • keyup:放开按键的时候改变ViewModel。
  • keypress:按下按键的时候改变ViewModel
  • afterkeydown:通过keydown事件来处理同步,算是一种比较好的同步方式。

示例代码:

//.W片段
<p>Your value: <input bind-value="someValue, valueUpdate: 'input'" /></p>
<p>You have typed: <span bind-text="someValue"></span></p>

//.js片段
this.someValue=justep.Bind.observable("edit me");

valueAllowUnset 属性

valueAllowUnset 只对select有用。示例代码:

//.W片段
<p>
 Select a country:
 <select bind-options="countries,
 optionsCaption: 'Choose one...',
 value: selectedCountry,
 valueAllowUnset: true"></select>
</p>

//.js片段
this.countries=['Japan', 'Bolivia', 'New Zealand'];
this.selectedCountry=justep.Bind.observable('Latvia');

在这段代码中,我们将valueAllowUnset设置为true,此时我们将value设置为“Lativia”时,列表中不存在此项,那么将会把selectedCountry设置为undefined,界面显示“Choose one…”项。

双向绑定、单项绑定和无绑定

示例代码:

//.W片段
<!-- 双向绑定,双向同步 -->
<p>First value: <input bind-value="firstValue" /></p>

<!-- 单项绑定,只能从textbox同步到model -->
<p>Second value: <input bind-value="secondValue" /></p>

<!-- 无绑定,textbox的改变不会引起任何改变 -->
<p>Third value: <input bind-value="secondValue.length > 8" /></p>

//.js片段
this.firstValue=justep.Bind.observable("hello");
this.secondValue="hello, again";

关于如何绑定可以在代码中看到。