KnockoutJS 3.X API 第四章 表单绑定(11) options绑定
目的
options绑定主要用于下拉列表中(即<select>元素)或多选列表(例如,<select size='6'>)。此绑定不能与除<select>元素之外的任何其他元素一起使用。
其值应该是一个数组(或监控属性数组)。
注意:对于多选列表,设置该选项被选中,或读取其中被选中的选项,需要使用的selectedOptions绑定。对于单选择列表,可以结合value绑定读取和写入选定的选项的。。
示例1:下拉列表
Destination country:
源码:
<p>
Destination country:
<select data-bind="options: availableCountries"></select>
</p> <script type="text/javascript">
var viewModel = {
// These are the initial options
availableCountries: ko.observableArray(['France', 'Germany', 'Spain'])
}; // ... then later ...
viewModel.availableCountries.push('China'); // Adds another option
</script>
示例2:多选列表
Choose some countries you would like to visit:
源码:
<p>
Choose some countries you would like to visit:
<select data-bind="options: availableCountries" size="5" multiple="true"></select>
</p> <script type="text/javascript">
var viewModel = {
availableCountries: ko.observableArray(['France', 'Germany', 'Spain'])
};
</script>
示例3:任意JS对象的下拉列表
Your country:
源码:
<p>
Your country:
<select data-bind="options: availableCountries,
optionsText: 'countryName',
value: selectedCountry,
optionsCaption: 'Choose...'"></select>
</p> <div data-bind="visible: selectedCountry"> <!-- Appears when you select something -->
You have chosen a country with population
<span data-bind="text: selectedCountry() ? selectedCountry().countryPopulation : 'unknown'"></span>.
</div> <script type="text/javascript">
// Constructor for an object with two properties
var Country = function(name, population) {
this.countryName = name;
this.countryPopulation = population;
}; var viewModel = {
availableCountries : ko.observableArray([
new Country("UK", 65000000),
new Country("USA", 320000000),
new Country("Sweden", 29000000)
]),
selectedCountry : ko.observable() // Nothing selected by default
};
</script>
示例4:任意JS对象的下拉列表并以计算的方式显示文本
源码:
<!-- Same as example 3, except the <select> box expressed as follows: -->
<select data-bind="options: availableCountries,
optionsText: function(item) {
return item.countryName + ' (pop: ' + item.countryPopulation + ')'
},
value: selectedCountry,
optionsCaption: 'Choose...'">
</select>
备注,示例4与示例3的唯一区别在于optionsText的显示方式。
参数
optionsCaption
有时候,你可能不希望默认选择选中任何特定选项。但单选择下拉列表中通常选择一些默认项目启动,因此,如何避免预选的东西,通常的解决方法是用一个特殊的虚拟选项,只是写着“选择项”或“请选择一个选项”或类似的东西,并具有在默认情况下选择了一个前缀的选项列表。
这很容易做到:只需添加额外的参数有名字
optionsCaption
,它的值是显示一个字符串。例如:<select data-bind='options: myOptions, optionsCaption: "Select an item...", value: myChosenValue'></select>
KO会前缀一个显示文本的项目列表“选择项目...”它的值是
undefined
。因此,如果myChosenValue
保持值undefined
,则虚设选项将被选中。如果optionsCaption
参数是监控属性,则初始项目的文本将根据监控属性值的变化而变化。optionsText
见上面的示例3,在这种情况下,你需要选择该对象的属性应显示为下拉列表或多选列表的文本。示例3显示了如何可以通过传递一个额外的参数指定属性名
optionsText
。如果你不希望下拉列表中的每个项目显示的只是一个简单的属性值的文本,你可以给
optionsText
选项传递一个JavaScript函数,并提供您自己任意的逻辑在表示对象的条件计算显示的文本。如示例4。optionsValue
类似
optionsText
,您还可以传递一个名为optionsValue的附加参数,以指定应使用哪些对象属性来设置KO生成的<option>元素上的value属性。 您还可以指定JavaScript函数来确定此值。 此函数将接收所选项作为其唯一参数,并应返回用于<option>元素的value属性的字符串。通常,您只想使用optionsValue作为一种确保KO在更新可用选项集时正确保留选择的方法。 例如,如果您通过Ajax调用重复获取“car”对象的列表,并且想要确保所选择的汽车被保留,您可能需要将optionsValue设置为“carId”或每个“car”对象具有的唯一标识符 ,否则KO不一定知道先前的“汽车”对象中的哪一个对应于新集合中的项目。
optionsIncludeDestroyed
有时你可能想将一个数组条目标记为已删除,但实际上没有真的删除。 这被称为非破坏性删除。
默认情况下,选项绑定将跳过(即隐藏)标记为已销毁的任何数组条目。 如果要显示已销毁的条目,请指定此附加参数,例如:
<select data-bind='options: myOptions, optionsIncludeDestroyed: true'></select>
optionsAfterRender
如果需要在生成的选项元素上运行一些自定义逻辑,可以使用optionsAfterRender回调。 见下文注2。
selectedOptions
对于多选列表,可以使用selectedOptions读取和写入所选状态。 技术上这是一个单独的绑定,你可以参考下一节的selectedOptions绑定。
valueAllowUnset
如果你想让Knockout允许你的模型属性获取在你的<select>元素没有相应条目的值(并通过使<select>元素为空,显示这个值),然后参见第四章 value绑定的valueAllowUnset。
备注1:设置/更改选项时保留选择
当选项绑定更改您的<select>元素中的选项集时,KO将尽可能不改变用户的选择。 因此,对于单选择下拉列表,仍将选择先前选择的选项值,而对于多选列表,仍将选择所有先前选择的选项值(除非您已删除 一个或多个选项)。
这是因为选项绑定试图独立于值绑定(控制单选列表的选择)和selectedOptions绑定(控制多选列表的选择)。
备注2:对生成的选项进行处理
如果需要在生成的选项元素上运行一些自定义逻辑,可以使用optionsAfterRender回调。 每当将一个选项元素插入到列表中时,将调用回调函数,并使用以下参数:
- 插入的
option
元素 - 与其绑定的数据项,或对于caption元素未定义的数据项
下面是一个使用optionsAfterRender向每个选项添加禁用绑定的示例:
源码:
<select size=3 data-bind="
options: myItems,
optionsText: 'name',
optionsValue: 'id',
optionsAfterRender: setOptionDisable">
</select> <script type="text/javascript">
var vm = {
myItems: [
{ name: 'Item 1', id: 1, disable: ko.observable(false)},
{ name: 'Item 3', id: 3, disable: ko.observable(true)},
{ name: 'Item 4', id: 4, disable: ko.observable(false)}
],
setOptionDisable: function(option, item) {
ko.applyBindingsToNode(option, {disable: item.disable}, item);
}
};
ko.applyBindings(vm);
</script>
KnockoutJS 3.X API 第四章 表单绑定(11) options绑定的更多相关文章
- KnockoutJS 3.X API 第四章 表单绑定(9) value绑定
目的 value绑定主要用于DOM元素给视图模型赋值用的.通常用于<input><select><textarea>等元素. value绑定与text绑定的区别在于 ...
- KnockoutJS 3.X API 第四章 表单绑定(10) textInput、hasFocus、checked绑定
textInput绑定目的 textInput绑定主要用于<input>或者<textarea>元素.他提供了DOM和viewmodel的双向更新.不同于value绑定,tex ...
- KnockoutJS 3.X API 第四章 表单绑定(6) click绑定
目的 click绑定主要作用是用于DOM元素被点击时调用相关JS函数.最常见用于button.input.a元素. 例如: You've clicked timesClick me var viewM ...
- KnockoutJS 3.X API 第四章 表单绑定(7) event绑定
目的 event绑定即为事件绑定,即当触发相关DOM事件的时候回调函数.例如keypress,mouseover或者mouseout等 例如: Mouse over me Details var vi ...
- KnockoutJS 3.X API 第四章 表单绑定(8) submit、enable、disable绑定
submit绑定目的 submit绑定即为提交绑定,通常用于form元素.这种绑定方式会打断默认的提交至服务器的操作.转而提交到你设定好的提交绑定回调函数中.如果要打破这个默认规则,只需要在回调函数中 ...
- KnockoutJS 3.X API 第四章 表单绑定(12) selectedOptions、uniqueName绑定
selectedOptions绑定目的 selectedOptions绑定控制当前选择多选列表中的哪些元素. 这旨在与<select>元素和选项绑定结合使用. 当用户选择或取消选择多选列表 ...
- KnockoutJS 3.X API 第四章 数据绑定(1) 文本及样式绑定
目录 本节将介绍六种文本绑定方式: visible绑定 text绑定 html绑定 css绑定 style绑定 attr绑定 可见文本绑定(visible) 使用visible绑定,来控制DOM元素的 ...
- KnockoutJS 3.X API 第四章(13) template绑定
目的 template绑定(模板绑定)使用渲染模板的结果填充关联的DOM元素. 模板是一种简单方便的方式来构建复杂的UI结构 . 下面介绍两种使用模板绑定的方法: 本地模板是支持foreach,if, ...
- JavaScript高级程序设计学习笔记第十四章--表单
1.在 HTML 中,表单是由<form>元素来表示的,而在 JavaScript 中,表单对应的则是 HTMLFormElement 类型. HTMLFormElement 继承了 HT ...
随机推荐
- DWG2SHP DXF2SHP 如何把AutoCAD的DWG,DXF文件转换为Esri ArcGIS的Shape文件
dwg是AutoCAD创立的一种图纸保存格式,已经成为二维CAD的标准格式,很多其他CAD为了兼容AutoCAD,也直接使用dwg作为默认工作文件. 地图shape文件由ESRI开发,一个ESRI的s ...
- isee - 创建项目 - 1
1.在本地web目录下创建一个新项目 D:\web> composer create-project laravel/laravel isee --prefer-dist 2.在vhosts.c ...
- Python 学习---------Day6
18章 模块:宏伟蓝图 import 使客户端(导入者)以一个整体获取一个模块 from 允许客户端从一个模块文件中获取特定的变量名 reload 在不中止Python程序的情况下,提供了一种重新载入 ...
- P1905生活大爆炸版 石头剪刀布
P1905生活大爆炸版 石头剪刀布 描述 石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头.如果两个人出拳一 样,则不分胜负.在<生活大爆炸>第二季第 8 集中出现了一种石头 ...
- Effecvive Java读书笔记(一):创建和销毁对象
I.考虑静态工厂方法替代构造器 优势:1.有清晰的方法名称,方便调用:多参数构造器易出现调用错误 2.不必每次调用都创建新对象 3.可以返回原返回类型的任何子类型 4.创建参数化类型实例的时候,代码简 ...
- ubuntu网络配置&&ubuntu apt-get错误解决办法
网络配置: 方式1:网卡通过DHCP自动获取IP地址 $ sudo gedit /etc/network/interfaces # 修改文件/etc/network/interfaces如下文 #-- ...
- Linux系统MySQL开启远程连接
1.远程连接上Linux系统,确保Linux系统已经安装上了MySQL数据库.登陆数据库.mysql -uroot -p(密码). 2.创建用户用来远程连接 GRANT ALL PRIVILEGES ...
- Python成长笔记 - 基础篇 (九)
创建一个socketserver 至少分以下几步: First, you must create a request handler class by subclassing the BaseRequ ...
- 萝卜白菜,给有所爱——C#和JAVA都会终将被时代淘汰
看到园子里又有一波试图掀起C#和JAVA的谁更好的争论,对于这些一直不断的争论,我觉得实在没有必要,黑格尔的存在即合理,中国的老古语说的萝卜白菜各有所爱,大家争论的再多其实卵用也没用,还不如趁着闲暇时 ...
- js继承理解(有引用)
具体栗子:http://www.cnblogs.com/ayqy/p/4471638.html(地下为自己理解总结,可能晦涩,链接详细) 1.父类实例赋予子类原型. 2.利用子类函数引用 父类.cal ...