WeX5数据绑定:options绑定
优质
小牛编辑
150浏览
2023-12-01
options绑定用来绑定select控件的option项,它只能用在select元素中,并且绑定值必须为数组。对于单选的下拉列表,选中值用value绑定;对于多选的列表,选中值用selectedOptions绑定。
示例代码
单选列表
//.W片段 <p> Destination country: <select bind-options="availableCountries"></select> </p> //.js片段 availableCountries=justep.Bind.observableArray(['France', 'Germany', 'Spain'])
多选列表
//.W片段 <p> Choose some countries you would like to visit: <select bind-options="availableCountries" size="5" multiple="true"></select> </p> //.js片段 availableCountries=justep.Bind.observableArray(['France', 'Germany', 'Spain']);
绑定任意对象
//.W片段 <p> Your country: <select bind-options="availableCountries" bind-optionsText= "'countryName'" bind-value= "selectedCountry" bind-optionsCaption= "'Choose...'"></select> </p> <div bind-visible="selectedCountry"> <!-- Appears when you select something --> You have chosen a country with population <span bind-text="selectedCountry.get() ? selectedCountry.get().countryPopulation : 'unknown'"></span>. </div> //.js片段 var Country = function (name, population) { this.countryName = name; this.countryPopulation = population; }; var Model = function(){ this.callParent(); this.availableCountries=justep.Bind.observableArray([ new Country("UK", 65000000), new Country("USA", 320000000), new Country("Sweden", 29000000) ]); this.selectedCountry=justep.Bind.observable(''); };
optionsText绑定方法
//.W片段 <!-- Same as example 3, except the <select> box expressed as follows: --> <select bind-options="availableCountries" bind-optionsText= "function (item) { return item.countryName + ' (pop: ' + item.countryPopulation + ')' }" bind-value= "selectedCountry" bind-optionsCaption= "'Choose...'"></select>
绑定规则:
options绑定将数组生成option节点,添加到select元素中。如果绑定值为字符串数组,option中显示的将是字符串本身;如果绑定值是object对象,在options绑定中,还需要设置optionsText,用来决定将如何显示绑定的对象,如果你需要,还可以使用optionsValue字段。
options绑定为双向绑定,如果绑定的是监视对象,则可以进行双向的更改。
其它参数
- optionsCaption:在下拉别表中,默认会选中一个option,但是通常我们不希望进行选中,而是为select添加一个“–请选择–”这样的一个选项。KO为我们考虑到了这种需求,我们可以使用optionsCaption来实现。
- optionsText:当我们将一个对象绑定到option上的时候,需要指定optionsText参数。optionsText参数是对象的一个属性,或者一个返回字符串的方法。
- optionsValue:当option绑定的是任意对象的时候,如果我们希望选中的值是一个字符串,我们可以指定optionsValue参数,参数的形式为对象的一个属性,或者一个返回字符串的方法。
- optionsIncludeDestroyed:在监视的数组对象中,如果有数组项被标记删除,默认情况下是不会显示出来的。如果想对已标记删除的数据进行显示,需要将optionsIncludeDestroyed设置为true。
- optionsAfterRender:在options被绘制完成之后调用,用来执行一些自定义的逻辑代码。
- selectedOptions:多选列表中的选中项。
- valueAllowUnset:当选中值在绑定对象中不存在时,允许将值设置为null