表单(三):select
选择框的value属性
<select name='location' id='selLocation'>
<option value='Sunnyvale,Ca'>Sunnyvale</option>
<option value='Los Angeles,Ca'>Los Angeles</option>
<option value='Mountain View,Ca'>Mountain View</option>
<option value=''>China</option>
<option>Australia</option>
</select>
如果用户选择了其中第一项,则选择框的值就是'Sunnyvale,Ca',如果文本为'China'的选项被选中,则选择框的值就是一个空字符串,因为其value
特性是空的。如果选择了最后一项,那么由于<option>中没有指定value特性,则选择框的值就是'Australia'.
<option>
每个<option>元素都有一个HTMLOptionElement对象表示,为了便于访问数据,HTMLOptionElement对象添加了下列属性
index:当前选项在options集合中的索引。
label:当前选项的标签;等价于HTML中的label特性。
selected:布尔值,表示当前选项是否被选中。
text:选项的文本。
value:选项的值
var selectbox = document.forms[0].elements['location'];
var text = selectbox.option[0].text; //选项的文本
var value = selectbox.option[0].value; //选项的值
选择选项
1、只允许选择一项对选择框,访问选中项对最简单方式,就是使用选择对selectedIndex属性
var selectedOption = selectbox.options[selectbox.selectedIndex];
//取得选中项之后,可以像下面这样显示该选项对信息:
var selectedIndex = selectbox.selectedIndex;
var selectedOption = selectbox.options[selectedIndex];
console.log('Select index: ' + selectedIndex + '\nSelected text: ' + selectedOption.text + '\nSelected value: ' + selectedOption.value);
2、对于可以选择多项的选择框,有一种选择选项的方式,就是取得对某一项对引用,然后对其selected属性设置为true.
selectbox.options[0].selected = true;
在允许多选对选择框中设置选项对selected属性,不会取消对其他选中项对选择,因而可以动态选中任意多个项。
要取得所有选中对项,可以循环遍历选项集合,然后测试每个选项对selected属性。
function getSelectedOptions(selectbox){
    var result = new Array();
    var option = null;
    for(var i=0,len=selectbox.options.length; i<len; i++){
        option = selectbox.options[i];
        if(option.selected){
            result.push(option);
        }
    }
    return result;
}
var selectbox = document.getElementById('selLocation');
var selectedOption = getSelectedOptions(selectbox);
var message = '';
for(var i=0,len=selectedOption.length; i<len; i++){
    message += 'Select index: ' + selectedOption[i].index + '\nSelected text: ' + selectedOption[i].text + '\nSelected value: ' + selectedOption[i].value
}
添加选项
1、使用dom方法
var newOption = document.createElement('option');
newOption.appendChild(document.createTextNode('Option text'));
newOption.setAttribute('value', 'Option value');
selectbox.appendChild(newOption);
2、使用Option构造函数,这个构造函数是dom出现之前就有的,一直遗留到现在。Option构造函数接受两个参数
文本(text)和值(value);第二个参数可选
var newOption = new Option('Option text', 'Option value');
selectbox.appendChild(newOption); //在ie8及之前版本中有问题
这种方式在除ie之外的浏览器都可以使用。
3、使用选择框的add()方法。dom规定这个方法接受两个参数:要添加的新选项和将位于新选项之后的选项。
var newOption = new Option('Option text', 'Option value');
selectbox.add(newOption, undefined); //最佳方案
想在列表中的最后添加一个选项,应该将第二个参数设置为null。在ie对add()方法的实现中,第二个参数是可选的,而且如果指定,该参数必须是新选项之后选项的索引。
兼容dom的浏览器要求必须指定第二个参数,因此编写跨浏览器的代码,就不能只传入一个参数。
如果不是最后一个,使用标准的dom技术和insertBefore()方法。
移动选项
1、使用dom的removeChild()方法
selectbox.removeChild(selectbox.options[0]);
2、使用选项框的remove()方法。接受一个参数,索引
selectbox.remove(0);
3、设置选项为null, dom出现之前浏览器的遗留机制。
selectbox.options[0] = null;
4、要清除所有的项,迭代
function clearSelectbox(selectbox){
    for(var i=0,len=selectbox.options.length; i<len; i++){
        selectbox.remove(0);
    }
}
移动和重排选择
1、从一个选择框的选项移动到另一个选择框
var selectbox1 = document.getElementById('selLocation1');
var selectbox2 = document.getElementById('selLocation2');
selectbox2.appendChild(selectbox1.options[0]);
移动选项和移除选项,都会重置每一个选项都index属性
2、重排选择框的顺序
var optionToMove = selectbox.options[1];
selectbox.insertBefore(optionToMove, selectbox.options[optionToMove.index-1]);
表单(三):select的更多相关文章
- 表单元素-select
		
<form> <select size="2"> <option value="JMS HADEN">JMS HADEN&l ...
 - vue.js中的表单radio,select,textarea的v-model属性的用法
		
只要是表单元素,其值已经不会再用value来定义了,但是placeholder还是可以用来设置默认值. section1--input:type="text" type=" ...
 - React 之form表单、select、textarea、checkbox使用
		
1.案例如下 import React from 'react'; /** * 非约束性组(类似defaultValue等属性,不可以程序修改): <input type="text& ...
 - Form表单三种提交按钮的区别?
		
1.<input type='button' id='btn' onclick='check()' value="提交"> 说明:只是普通的按钮(不附带提交功能),不会 ...
 - angular $http 与form表单的select
		
产品线 产品 版本 代码是联动关系 ng-model 绑定数据 设置默认值 ng-options 填充option ng-change 选项变化时的操作截图如下: html <!DOCTYPE ...
 - 前端 HTML form表单标签 select标签 option 下拉框
		
<select></select> select里面通常跟option配合使用 <!DOCTYPE html> <html lang="en&quo ...
 - html5 表单 填表 select 下拉 textarea多行文本 output Js计算结果
		
<select> 下拉 <select>下有很多属性 name 其实有name就有value了,因为button提交的都是? name=value的格式, ...
 - 第三百一十一节,Django框架,Form表单验证
		
第三百一十一节,Django框架,Form表单验证 表单提交 html <!DOCTYPE html> <html lang="en"> <head& ...
 - form表单select联动
		
下拉列表:二级联动菜单 Select对象的常用属性 options[]:返回所有option组成的一个数组: name:名称 value:option的value的值 length:设置或读取opti ...
 
随机推荐
- WCF的三种模式
			
WCF通信的3种模式 1.正常模式:客户端调取接口->等待服务响应->接受响应->执行客户端后面代码(wcf服务有入参,有返回值) 2.数据报模式:客户端调取接口->不等待响应 ...
 - 爬虫(GET)——爬取多页的html
			
工具:python3 目标:将编写的代码封装,不同函数完成不同功能,爬取任意页数的html 新学语法:with open as 除了有更优雅的语法,with还可以很好的处理上下文环境产生的异常. # ...
 - 虚拟机 ---- 最小化安装无法使用tab补全键
			
解决方法: 安装 yum -y install bash-completion 然后重启 注意:挂载时使用绝对路径的cdrom挂载, ls -l /dev/cdromvim /etc/fstab — ...
 - leetcode 925. 长按键入
			
题目描述: 你的朋友正在使用键盘输入他的名字 name.偶尔,在键入字符 c 时,按键可能会被长按,而字符可能被输入 1 次或多次. 你将会检查键盘输入的字符 typed.如果它对应的可能是你的朋友的 ...
 - python的基础数据类型
			
Python基础数据类型 定义: int => 数字类型 str => 字符串数据类型 bool =>布尔值,True False list 列表,用来存放大量数据 [ ...
 - EDP项目结构规范心得
			
本文结合最近心得,希望对项目结构方面知识进行归纳,包括两部分 一.目录结构的说明 二.目录结构标准规范(以百度efe团队为例) 下面切入正题: 一.项目目录结构说明: 项目结构具体说明: 1.src目 ...
 - Oracle安装后忘记用户名或密码+创建新登陆用户
			
新安装的Oracle11g,不料在使用的时候没记住安装时的用户名和密码. 不用担心,打开sqlplus. 按如下步骤,新建一个登陆用户: 第一步:以sys登陆 sys/密码 as sysdba 此 ...
 - POJ 1860——Currency Exchange——————【最短路、SPFA判正环】
			
Currency Exchange Time Limit:1000MS Memory Limit:30000KB 64bit IO Format:%I64d & %I64u S ...
 - ArcSDE空间数据库中SDE用户使用探讨(转)
			
ArcSDE作为空间数据库解决方案,应用非常广泛,本短文将尝试描述SDE的工作机制,简要说明空间数据 库中SDE用户的使用方法. ArcSDE如何工作 ArcSDE属于中间件技术,其本身并不能够存储空 ...
 - Struts2_HelloWorld_6
			
为 eclipse 在编写 xml配置文件时提供提示,需要加上dtd或xls的标签定义文件的路径,具体操作: 1.Window——Preferences——XML Catalog 2.添加 dtd 文 ...