前面的话
选择框是通过<select>和<option>元素创建的,又称为下拉列表框。为了方便与这个控件交互,除了所有表单字段共有的属性和方法外,javascript还提供了一些属性和方法。本文将详细介绍选择框脚本
select
select元素用来定义一个下拉列表,包含任意数量的option和optgroup元素。select元素包含以下javascript属性
autofocus 是否在页面加载后文本区域自动获得焦点(IE9-浏览器不支持)
disabled 是否禁用该下拉列表
form 表示文本区域所属的一个或多个表单
multiple 是否可选择多个选项
name 表示下拉列表的名称
size 表示下拉列表中可见选项的数目
options 表示所包含的options的数组
selectedOptions 表示所选择的options的数组(IE浏览器不支持)
selectedIndex 表示所选择的第一个option的索引值
下面对一些重要属性进行详细介绍
multiple
multiple属性表示是否允许多项选择
type
选择框的type属性有两种,一种是'select-one',表示单选;另一种是'select-multiple',表示多选
value
选择框的value属性由当前选中项决定
1、如果没有选中的项,则选择框的value属性保存空字符串
2、如果有一个选中项,而且该项的value特性已经在HTML中指定,则选择框的value属性等于选中项的value特性。即使value特性的值是空字符串,也同样遵循此条规则
3、如果有一个选中项,但该项的value特性在HTML中未指定,则选择框的value属性等于该项的文本
4、如果有多个选中项,则选择框的value属性将依据前两条规则取得第一个选中项的值
[注意]IE8-浏览器只支持value属性的值,不支持选择的文本值
selectedIndex
selectedIndex属性返回基于0的选中项的索引,如果没有选中项,则值为-1。对于支持多选的控件,只保存选中项中第一项的索引
size
size属性表示选择框的可见行数
options
options属性表示控件中所有的<option>元素
option
在DOM中,每个<option>元素都有一个HTMLOptionElement对象表示。为便于访问数据, HTMLOptionElement对象也定义了一些属性
[注意]IE浏览器不支持为<option>元素设置display:none
index
index属性表示当前选项在options集合中的索引
label
label属性表示当前选项的标签
[注意]IE9-浏览器不支持
selected
selected属性表示当前选项是否被选中。将这个属性设置为true可以选中当前选项
text
text属性表示选项的文本
value
value属性表示选项的值
[注意]在未指定value特性的情况下,IE8会返回空字符串;而其他浏览器返回text属性的值
添加选项
【1】添加选项可以使用DOM的appendChild()或insertBefore()方法
【2】可以使用选择框的add()方法,add(newoption,reloption)方法向控件中插入新<option>元素,其位置在相关项(reloption)之前
使用Option构造函数来创建新选项,接受两个参数:文本(text)和值(value),第二个参数可选
移除选项
与添加选项类似,移除选项的方式也有很多种
【1】使用DOM的removeChild()方法
【2】使用选择框的remove()方法。这个方法接受一个参数,即要移除选项的索引
[注意]使用该方法的好处是,若不存在被移除选项的索引,不会报错,只是静默失败
【3】将相应选项设置为null
[注意]该方法同样不会报错