前面的话
选择框是通过<select>和<option>元素创建的,又称为下拉列表框。为了方便与这个控件交互,除了所有表单字段共有的属性和方法外,javascript还提供了一些属性和方法。本文将详细介绍选择框脚本
<select>
首先介绍关于<select>元素的相关属性
multiple
multiple属性表示是否允许多项选择
<select name="test" id="test"> <option>1</option> <option>2</option> <option>3</option> </select> <button id="btn">是否多选</button> <script> btn.onclick = function(){ test.multiple = !test.multiple; } </script>
type
选择框的type属性有两种,一种是'select-one',表示单选;另一种是'select-multiple',表示多选
<select name="test" id="test"> <option>1</option> <option>2</option> <option>3</option> </select> <button id="btn">是否多选</button> <div id="result"></div> <script> btn.onclick = function(){ test.multiple = !test.multiple; result.innerHTML = test.type; } </script>
value
选择框的value属性由当前选中项决定
1、如果没有选中的项,则选择框的value属性保存空字符串
2、如果有一个选中项,而且该项的value特性已经在HTML中指定,则选择框的value属性等于选中项的value特性。即使value特性的值是空字符串,也同样遵循此条规则
3、如果有一个选中项,但该项的value特性在HTML中未指定,则选择框的value属性等于该项的文本
4、如果有多个选中项,则选择框的value属性将依据前两条规则取得第一个选中项的值
[注意]IE8-浏览器只支持value属性的值,不支持选择的文本值
<select name="test" id="test"> <option value="a">1</option> <option value="b">2</option> <option>3</option> </select> <button id="btn1">是否多选</button> <button id="btn2">获取value值</button> <div id="result"></div> <script> btn1.onclick = function(){ test.multiple = !test.multiple; } btn2.onclick = function(){ result.innerHTML = test.value; } </script>
selectedIndex
selectedIndex属性返回基于0的选中项的索引,如果没有选中项,则值为-1。对于支持多选的控件,只保存选中项中第一项的索引
<select name="test" id="test"> <option value="a">1</option> <option value="b">2</option> <option>3</option> </select> <button id="btn1">是否多选</button> <button id="btn2">获取索引</button> <div id="result"></div> <script> btn1.onclick = function(){ test.multiple = !test.multiple; } btn2.onclick = function(){ result.innerHTML = test.selectedIndex; } </script>
size
size属性表示选择框的可见行数
<select name="test" id="test"> <option value="a">1</option> <option value="b">2</option> <option>3</option> </select> <button id="btn1">可见1行</button> <button id="btn2">可见2行</button> <button id="btn3">可见3行</button> <div id="result"></div> <script> btn1.onclick = function(){ test.size = 1; } btn2.onclick = function(){ test.size = 2; } btn3.onclick = function(){ test.size = 3; } </script>
options
options属性表示控件中所有的<option>元素
<select name="test" id="test"> <option value="a">1</option> <option value="b">2</option> <option>3</option> </select> <script> //[option, option, option, selectedIndex: 0] console.log(test.options) </script>
<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属性的值
<select name="test" id="test"> <option value="a" selected>1</option> <option value="b">2</option> <option>3</option> </select> <script> var option = test.options[0]; console.log(option.index);//0 console.log(option.label);//1,IE9-浏览器返回空字符串'' console.log(option.selected);//true console.log(option.text);//1 console.log(option.value);//a </script>
添加选项
【1】添加选项可以使用DOM的appendChild()或insertBefore()方法
<select name="test" id="test"> <option>1</option> <option>3</option> </select> <button id="btn">增加选项2</button> <script> btn.onclick = function(){ var newOption = document.createElement('option'); newOption.innerHTML = 2; test.insertBefore(newOption,test.options[1]); } </script>
【2】可以使用选择框的add()方法,add(newoption,reloption)方法向控件中插入新<option>元素,其位置在相关项(reloption)之前
使用Option构造函数来创建新选项,接受两个参数:文本(text)和值(value),第二个参数可选
<select name="test" id="test"> <option>1</option> <option>3</option> </select> <button id="btn">增加选项2</button> <script> btn.onclick = function(){ var newOption = new Option('2'); test.add(newOption,1); } </script>
移除选项
与添加选项类似,移除选项的方式也有很多种
【1】使用DOM的removeChild()方法
<select name="test" id="test"> <option>1</option> <option>2</option> <option>3</option> </select> <button id="btn">移除选项2</button> <script> btn.onclick = function(){ test.removeChild(test.options[1]); } </script>
【2】使用选择框的remove()方法。这个方法接受一个参数,即要移除选项的索引
[注意]使用该方法的好处是,若不存在被移除选项的索引,不会报错,只是静默失败
<select name="test" id="test"> <option>1</option> <option>2</option> <option>3</option> </select> <button id="btn">移除选项2</button> <script> btn.onclick = function(){ test.remove(1); } </script>
【3】将相应选项设置为null
[注意]该方法同样不会报错
<select name="test" id="test"> <option>1</option> <option>2</option> <option>3</option> </select> <button id="btn">移除选项2</button> <script> btn.onclick = function(){ test.options[1] = null; } </script>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]