js操作select标签_js的select标签对应的属性和方法_hhhh2012的博客-程序员秘密

技术标签: js  页面  

html中的select标签
javascript对它们的操作 
一、基础理解  
复制代码代码如下:

var e = document.getElementById("selectId"); 
e. options= new Option("文本","值") ; 
//创建一个option对象,即在<select>标签中创建一个或多个<option value="值">文本</option> 
//options是个数组,里面可以存放多个<option value="值">文本</option>这样的标签 

1:options[ ]数组的属性: 
length属性---------长度属性 
selectedIndex属性--------当前被选中的框中的文本的索引值,此索引值是内存自动分配的(0,1,2,3.....)对应(第一个文本值,第二个文本值,第三个文本值,第四个文本值..........) 
2:单个option的属性(---obj.options[obj.selecedIndex]是指定的某个<option>标签,是一个---) 
text属性---------返回/指定 文本 
value属性------返回/指定 值,与<options value="...">一致。 
index属性-------返回下标, 
selected 属性-------返回/指定该对象是否被选中.通过指定 true 或者 false,可以动态的改变选中项 
defaultSelected 属性-----返回该对象默认是否被选中。true / false。 
3:option的方法 
增加一个<option>标签-----obj.options.add(new("文本","值"));<增> 
删除一个<option>标签-----obj.options.remove(obj.selectedIndex)<删> 
获得一个<option>标签的文本-----obj.options[obj.selectedIndex].text<查> 
修改一个<option>标签的值-----obj.options[obj.selectedIndex]=new Option("新文本","新值")<改> 
删除所有<option>标签-----obj.options.length = 0 
获得一个<option>标签的值-----obj.options[obj.selectedIndex].value 
注意: 
a:上面的写的是如这样类型的方法obj.options.function()而不写obj.funciton,是因为为了考虑在IE和FF 下的兼容,如obj.add()只能在IE中有效. 
b:obj.option中的option不需要大写,new Option中的Option需要大写 
二 、应用  
复制代码代码如下:

<html> 
<head> 
<script language="javascript"> 
function number(){ 
var obj = document.getElementById("mySelect"); 
//obj.options[obj.selectedIndex] = new Option("我的吃吃","4");//在当前选中的那个的值中改变 
//obj.options.add(new Option("我的吃吃","4"));再添加一个option 
//alert(obj.selectedIndex);//显示序号,option自己设置的 
//obj.options[obj.selectedIndex].text = "我的吃吃";更改值 
//obj.remove(obj.selectedIndex);删除功能 

</script> 
</head> 
<body> 
<select id="mySelect"> 
<option>我的包包</option> 
<option>我的本本</option> 
<option>我的油油</option> 
<option>我的担子</option> 
</select> 
<input type="button" name="button" value="查看结果" οnclick="number();"> 
</body> 
</html> 

1.动态创建select 
复制代码代码如下:

function createSelect(){ 
var mySelect = document.createElement("select"); 
mySelect.id = "mySelect"; 
document.body.appendChild(mySelect); 


2.添加选项option 
复制代码代码如下:

function addOption(){ 
//根据id查找对象, 
var obj=document.getElementById('mySelect'); 
//添加一个选项 
obj.add(new Option("文本","值")); //这个只能在IE中有效 
obj.options.add(new Option("text","value")); //这个兼容IE与firefox 


3.删除所有选项option 
复制代码代码如下:

function removeAll(){ 
var obj=document.getElementById('mySelect'); 
obj.options.length=0; 


4.删除一个选项option 
复制代码代码如下:

function removeOne(){ 
var obj=document.getElementById('mySelect'); 
//index,要删除选项的序号,这里取当前选中选项的序号 
var index=obj.selectedIndex; 
obj.options.remove(index); 


5.获得选项option的值 
复制代码代码如下:

var obj=document.getElementById('mySelect'); 
var index=obj.selectedIndex; //序号,取当前选中选项的序号 
var val = obj.options[index].value; 

6.获得选项option的文本 
复制代码代码如下:

var obj=document.getElementById('mySelect'); 
var index=obj.selectedIndex; //序号,取当前选中选项的序号 
var val = obj.options[index].text; 

7.修改选项option 
复制代码代码如下:

var obj=document.getElementById('mySelect'); 
var index=obj.selectedIndex; //序号,取当前选中选项的序号 
var val = obj.options[index]=new Option("新文本","新值"); 

8.删除select 
复制代码代码如下:

function removeSelect(){ 
var mySelect = document.getElementById("mySelect"); 
mySelect.parentNode.removeChild(mySelect); 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//ZH-CN" "http://www.w3.org/TR/html4/strict.dtd"> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html"> 
<head> 
<script language=JavaScript> 
function $(id) 

return document.getElementById(id) 

function show() 

var selectObj=$("area") 
var myOption=document.createElement("option") 
myOption.setAttribute("value","10") 
myOption.appendChild(document.createTextNode("上海")) 
var myOption1=document.createElement("option") 
myOption1.setAttribute("value","100") 
myOption1.appendChild(document.createTextNode("南京")) 
selectObj.appendChild(myOption) 
selectObj.appendChild(myOption1) 

function choice() 

var index=$("area").selectedIndex; 
var val=$("area").options[index].getAttribute("value") 
if(val==10) 

var i=$("context").childNodes.length-1; 
var remobj=$("context").childNodes[i]; 
remobj.removeNode(true) 
var sh=document.createElement("select") 
sh.add(new Option("浦东新区","101")) 
sh.add(new Option("黄浦区","102")) 
sh.add(new Option("徐汇区","103")) 
sh.add(new Option("普陀区","104")) 
$("context").appendChild(sh) 

if(val==100) 

var i=$("context").childNodes.length-1; 
var remobj=$("context").childNodes[i]; 
remobj.removeNode(true) 
var nj=document.createElement("select") 
nj.add(new Option("玄武区","201")) 
nj.add(new Option("白下区","202")) 
nj.add(new Option("下关区","203")) 
nj.add(new Option("栖霞区","204")) 
$("context").appendChild(nj) 


function calc() 

var x=$("context").childNodes.length-1; 
alert(x) 

function remove() 

var i=$("context").childNodes.length-1; 
var remobj=$("context").childNodes[i]; 
remobj.removeNode(true) 

</script> 
<body><div id="context"> 
<select id="area" on 
change="choice()"> 
</select> 
</div> 
<input type=button value="显示" οnclick="show()"> 
<input type=button value="计算结点" οnclick="calc()"> 
<input type=button value="删除" οnclick="remove()"> 
</body> 
</html> 

根据这些东西,自己用JQEURY AJAX+JSON实现了一个小功能如下: 
JS代码:(只取了于SELECT相关的代码) 
复制代码代码如下:

/** 
* @description 构件联动下拉列表 (用JQUERY 的AJAX配合JSON实现) 
* @prarm selectId 下拉列表的ID 
* @prarm method 要调用的方法名称 
* @prarm temp 此处存放软件ID 
* @prarm url 要跳转的地址 
*/ 
function linkAgeJson(selectId,method,temp,url){ 
$j.ajax({ 
type: "get",//使用get方法访问后台 
dataType: "json",//返回json格式的数据 
url: url,//要访问的后台地址 
data: "method=" + method+"&temp="+temp,//要发送的数据 
success: function(msg){//msg为返回的数据,在这里做数据绑定 
var data = msg.lists; 
coverJsonToHtml(selectId,data); 

}); 

/** 
* @description 将JSON数据转换成HTML数据格式 
* @prarm selectId 下拉列表的ID 
* @prarm nodeArray 返回的JSON数组 

*/ 
function coverJsonToHtml(selectId,nodeArray){ 
//get select 
var tempSelect=$j("#"+selectId); 
//clear select value 
isClearSelect(selectId,'0'); 
var tempOption=null; 
for(var i=0;i<nodeArray.length;i++){ 
//create select Option 
tempOption= $j('<option value="'+nodeArray[i].dm+'">'+nodeArray[i].mc+'</option> '); 
//put Option to select 
tempSelect.append(tempOption); 

// 获取退化构件列表 
getCpgjThgl(selectId,'thgjDm'); 

/** 
* @description 清空下拉列表的值 
* @prarm selectId 下拉列表的ID 
* @prarm index 开始清空的下标位置 
*/ 
function isClearSelect(selectId,index){ 
var length=document.getElementById(selectId).options.length; 
while(length!=index){ 
//长度是在变化的,因为必须重新获取 
length=document.getElementById(selectId).options.length; 
for(var i=index;i<length;i++) 
document.getElementById(selectId).options.remove(i); 
length=length/2; 


/** 
* @description 获取退化构件列表 
* @prarm selectId1 引用软件下拉列表的ID 
* @prarm selectId2 退化构件下拉列表的ID 
*/ 
function getCpgjThgl(selectId1,selectId2){ 
var obj1=document.getElementById(selectId1);//引用软件下拉列表 
var obj2=document.getElementById(selectId2);//退化构件下拉列表 
var len=obj1.options.length; 
//当引用软件列表长度等于1时返回,不做操作 
if(len==1){ 
return false; 

//清空下拉列表的值,两种方式都可以 
// isClearSelect(selectId2,'1'); 
document.getElementById(selectId2).length=1; 
for(var i=0;i<len; i++){ 
var option= obj1.options[i]; 
//引用软件被选中项不加入 
if(i!=obj1.selectedIndex){ 
//克隆OPTION并添加到SELECT中 
obj2.appendChild(option.cloneNode(true)); 




HTML代码: 
复制代码代码如下:

<TABLE width="100%" border=0 align="left" cellPadding=0 cellSpacing=1> 
<tr> 
<td class="Search_item_18"> <span class="Edit_mustinput">*</span>引用软件:</td> 
<td class="Search_content_82"> 
<input name="yyrjMc" id="yyrjMc" type="text" class="Search_input" tabindex="3" size="30" > 
<input name="yyrjDm" id="yyrjDm" type="hidden" > 
<input type="button" class="Search_button_select" 
onClick="linkAgeTree('linkage','yyrjtree','yyrjMc','yyrjDm','linkageTree','1');" value="选择..."> 
</td> 
</tr> 
<tr> 
<td class="Search_item"> <span class="Edit_mustinput">*</span>引用分版:</td> 
<td class="Search_content" id="yyfb"> 
<select name="yyfbDm" style="width:160" id="yyfbDm" onChange="getCpgjThgl('yyfbDm','thgjDm')"> 
</select> 
</td> 
</tr> 
<tr> 
<td class="Search_item">退化构件:</td> 
<td class="Search_content" id="thgj"> 
<select name="thgjDm" style="width:160" id="thgjDm"> 
<option value="-1" selected>无</option> 
</select> 
</td> 
</tr> 
</TABLE> 
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/hhhh2012/article/details/8610336

智能推荐

vega prime今天突然不能运行,提示vsgu::initialization faild ! Unable to check out vsg_rtl license._努力奋斗的小兵的博客-程序员秘密

vega prime之前运行的好好的,今天早上突然不能运行,提示:   vsgu::initialization faild ! Unable to check out vsg_rtl license.  经排查,原来是昨天修改了计算机的mac地址,因为vp的license文件绑定了计算机的mac地址,导致license文件无效,程序无法启动,把mac地址改回来,问题解决!

Process Monitor_processmonitor_无名无奈的博客-程序员秘密

1. Process Monitor介绍Process Monitor是一个用于Windows的高级监视工具,它显示实时文件系统、注册表和进程/线程活动。它结合了两个遗留的Sysinternals实用程序Filemon和Regmon的特性,并添加了一系列增强功能,包括丰富的和非破坏性的过滤、全面的事件属性(如会话id和用户名)、可靠的进程信息、对每个操作提供集成符号支持的完整线程堆栈、同时记录到...

Coco2d-x精品教程十篇_anlun的博客-程序员秘密

Coco2d-x精品教程十篇who1753Cocos2d, 资源分享围观1099次暂无评论注:点击小标题可查看各篇对应的详情1、基于Cocos2d-x3.0集成物理特性的精确点击测试   使用Cocos2d-x 3.0版本的一个基于chipmunk的集成物理特效,来作Cocos2d-x游戏的精确点击测试,效果如下:2、用Cocos

2021年安全员-C证(陕西省)报名考试及安全员-C证(陕西省)考试总结_陕西省公路交通安全员_童话小镇(王雅丽)的博客-程序员秘密

题库来源:安全生产模拟考试一点通公众号小程序安全员-C证(陕西省)报名考试根据新安全员-C证(陕西省)考试大纲要求,安全生产模拟考试一点通将安全员-C证(陕西省)模拟考试试题进行汇编,组成一套安全员-C证(陕西省)全真模拟考试试题,学员可通过安全员-C证(陕西省)考试总结全真模拟,进行安全员-C证(陕西省)自测。1、【判断题】铲运机上、下坡道时,应低速行驶,不得中途换档,下坡时不得空档滑行。()(√)2、【判断题】生产经营单位的主要负责人和安全生产管理人员必须具备与本单位所从事的生产...

PyQt5入门(七)常用控件_pyqt5控件_深海鱼肝油ya的博客-程序员秘密

按钮控件(QpushButton)QAbstractButton(所有按钮控件的父类)QPushButton(普通按钮)AToolButton(工具条按钮)QRadioButton(单选框按钮)QCheckBox(复选框按钮)代码:import sysfrom PyQt5.QtCore import *from PyQt5.QtGui import *from PyQt5.QtWidgets import *class QPushButtonDemo(QDialo.

浅谈去哪儿算法,搜索结果打乱,_m_参数,headers,pre关键参数等_天下无虫的博客-程序员秘密

前言本文仅供学习参考,如有侵权,请私信删除由于版权问题,本文所展示的代码并非完整代码,也不提供相关工具,关键参数只提供思路。登录登录的请求如下:https://user.qunar.com/mobile/doLogin.jsp请求参数:ret: https://pay.qunar.com/mobile/h5/personalcenter/myaccount/index.htmusername: 18888888888password: 123456vcode: remember: 1

随便推点

Java实现点击导出excel页面遮罩屏蔽,下载完成后解除遮罩_若依框架,导出excel的遮罩层怎么取消_Java-xy²的博客-程序员秘密

前端jsp页面代码:&lt;input type="hidden" id="txtendflag"/&gt;js代码://导出function getExport(procId) { var lindex = layer.load('1', { shade: [0.5, '#000'] //0.1透明度的白色背景 }); window.location.href = '${ctx}/manage/list/export?keyId=' + keyId

loginCheck_吓的瓜子都飞了的博客-程序员秘密

loginCheck&amp;lt;%@page import=&quot;java.sql.*&quot;%&amp;gt;&amp;lt;%@page contentType=&quot;text/html&quot; pageEncoding=&quot;gbk&quot;%&amp;gt;&amp;lt;!DOCTYPE html&amp;gt;&amp;lt;html&amp;gt; &amp;lt;head&amp;gt; &amp;lt;meta http-eq

计算机网络学习笔记之数据链路层的流量控制与可靠传输机制_链路的成本度量以 msec 表示链路上的单向传播延迟(假设延迟_FriendshipT的博客-程序员秘密

计算机网络学习笔记之数据链路层的流量控制与可靠传输机制数据链路层的流量控制与可靠传输机制流量控制、可靠传输与滑动窗口机制单帧滑动窗口与停止-等待协议多帧滑动窗口与后退N帧协议(GBN)多帧滑动窗口与选择重传协议(SR)参考文献数据链路层的流量控制与可靠传输机制流量控制、可靠传输与滑动窗口机制流量控制涉及对链路上的帧的发送速率的控制,以使接收方有足够的缓冲空间来接收每个帧。例如,在面向帧的自动重传请求系统中,当待确认帧的数量增加时,有可能超出缓冲存储空间而造成过载。流量控制的基本方法是由接收方控制发

Django模型操作常用方法_ab123334的博客-程序员秘密

1.Save()基本方法:object.save()save顾名思义是保存的意思,在django中既可以进行新增也可以进行修改操作。具体判定的算法如下:1.如果对象的主键属性为一个求值为True的值(例如,非None值或非空字符串),Django将执行UPDATE。2.如果对象的主键属性没有设置或者UPDATE没有更新任何记录,Django将执行INSERT。Save...

小白学opengl之 获取模型视图矩阵和投影矩阵_opengl 获取当前矩阵_kyowill的博客-程序员秘密

#include #include #include #include #include using namespace std;static int shoulder=0,elbow=0,finger=0;void init(void){ glClearColor(0,0,0,0); glShadeModel(GL_FLAT);}void display(void)

推荐文章

热门文章

相关标签