js中创建html标签、添加select下默认的option的value和text、删除select元素节点下所有的OPTION节点
2014-10-17 11:33
1096 查看
<pre name="code" class="java">jsp 中的下拉框标签:
<s:select name="sjx" id="sjx" list="sjxList" listKey="BM" listValue="MC" size="20" cssStyle="width:100%;height:70px; border:0" multiple="true"></s:select>
<pre name="code" class="html">
multiple="true"意思是支持选择多个。
js中灵活创建select标签下的项的方式:
var oSelect = $("sjx");<span style="white-space:pre"> //sjx为html或jsp页面上的select标签的id,如果使用Extjs的话,可以用EXT.getDom('sjx')获取标签 var oOption = document.createElement("OPTION"); //js中创建select标签下的OPTION子标签 oSelect.options.add(oOption);<span style="white-space:pre"> //将新建的OPTION子标签添加到select标签下 oOption.value = "001";<span style="white-space:pre"> //内容对应的value值 oOption.innerHTML ="小苹果";<span style="white-space:pre"> //显示的下拉框的内容 ...以此类推
Note:js中的这种方式,在特定的场合是比较有用的,比如:这里请求不返回特定界面,也就是不刷新整个界面。而是采用Ajax方式的异步请求做一些局部的数据请求,那么这个时候下面strut2的方式,就会无效。
<pre name="code" class="java"><pre name="code" class="java">for(...){ HashMap<String,Object> map = new HashMap<String,Objcet>(); map.put("BM","001"); map.put("MC","小苹果"); sjxList.add(map); }
另外一种方式,也是非常常用的:利用struts2的特性,在Action中定义一个List<Object>变量(以本例为例,命名为:sjxList),并设置set、get方法。
通过一个 HashMap 对象,添加内容,比如:
</pre>返回界面时,将在界面的select下拉框中显示“小苹果”。
</pre><pre code_snippet_id="487056" snippet_file_name="blog_20141017_5_1612209" name="code" class="javascript"><pre name="code" class="html">最简单的一种方式: 直接在jsp页面手动添加select标签的OPTION项 <html> <body> <form> <select id="cars" name="cars"> <option value="volvo">Volvo</option> <option value="binli">Binli</option> <option value="mazda" selected="selected">Mazda</option> <option value="audi">Audi</option> </select> </form> </body> </html>
删除select标签节点下所有的OPTION节点
方法一:
Js代码
function DeleteOptions() { var obj = document.getElementsByTagName("select")[0]; var selectOptions = obj.options; var optionLength = selectOptions.length; for(var i=0;i <optionLength;i++) { obj.removeChild(selectOptions[0]); } }
方法二:(那右边的Select中的所有option移到左边的Select)
Js代码
function MoveAllRightBtn(){ var columnlength=$('queryColumn').length; var TempText; var TempValue; for(var i=0;i<columnlength;i++){ TempText=$('queryColumn').options[i].text; TempValue=$('queryColumn').options[i].value; $('queryColumn').remove(i); $('SearchqqueryColumn').options.add(new Option(TempText,TempValue)); } }
以上两个方法都不够好!因为它们一次性都册除不了,因为删除了一个它的$('queryColumn')在option的序号就变了!
简单最优的方法如下:(只需将length置0)
Js代码
$('SearchqqueryColumn').options.length = 0;
Js代码
<script> function clearOption() { document.getElementById("testSelect").options.length = 0; } </script>
(那右边的Select中的所有option移到左边的Select)实现如下:
Js代码
function MoveAllRightBtn(){ var columnlength=$('queryColumn').options.length; var TempText; var TempValue; for(var i=0;i<columnlength;i++){ TempText=$('queryColumn').options[i].text; TempValue=$('queryColumn').options[i].value; $('SearchqqueryColumn').options.add(new Option(TempText,TempValue)); } $('queryColumn').options.length = 0; }
相关文章推荐
- js中创建html标签、加入select下默认的option的value和text、删除select元素节点下全部的OPTION节点
- js添加select下默认的option的value和text的方法
- js添加select下默认的option的value和text的方法
- JS对HTML标签select的获取、添加、删除操作
- JS获取当前年份,添加到HTML标签 select 的 option里
- HTML select标签 获取选中的option的value及Text内容
- JS对HTML标签select的获取、添加、删除操作
- 【JS学习笔记】07 添加和删除节点(HTML 元素)
- [置顶] 【代码库】删除select元素节点下所有的OPTION节点
- [thml]HTML select标签 获取选中的option的value及Text内容
- jQuery操作Select选择的Text和Value(获取/设置/添加/删除)
- html中select标签获取选中value和text
- 使用js对select动态添加和删除OPTION示例代码
- JS动态添加与删除select中的Option对象(示例代码)
- JQuery给元素添加/删除节点比如select
- select中添加、修改、删除option元素
- select中添加、修改、删除option元素
- Select的动态取值(Text,value),添加,删除。兼容IE,FireFox
- javascript想select标签中添加option元素
- js 对html 元素操作,添加删除修改