js动态添加options(转载)
JS动态添加Option的几种方式
在处理表单的时候,经常会有这样的需求:给定一定的数据来生成某个select的option,或者更进一步,某些option或许预先选中或者有高亮显示。
下面我们就来温习一下几种option的创建方式。这个需求要求某些选项要预先有高亮显示,可以通过添加class来处理。
首先定义一个高亮的class,为了简单处理,只定义红色高亮:
.hot-games{
background-color: #f00;
}
</style>
然后预先定义一些用来生成选项的数据:
<script type="text/javascript">
var gameOptions = {
"options" : [
{
"name" : "魔兽世界",
"value" : "50007361",
"isHot" : "false"
},
{
"name" : "龙之谷",
"value" : "50007937",
"isHot" : "false"
},
{
"name" : "永恒之塔",
"value" : "50007385",
"isHot" : "true"
},
{
"name" : "奇迹世界",
"value" : "50007800",
"isHot" : "false"
}
]
};
</script>
这里是select元素,需要制定id和name属性:
大致有三种方案可以增加option,一种是通过new Option() 构造函数,第二种是通过select.add()函数,第三种是通过增加innerHTML。下面比较一下三种方式的异同:
首先获取到select元素:
第一种方案,通过new Option()构造函数,该函数属0级DOM,所有浏览器都支持:
for(var i=0, j=gameOptions.options.length; i<j; i++){
gameCat.options[i] = new Option(gameOptions.options[i].name, gameOptions.options[i].value);
if(gameOptions.options[i].isHot == 'true'){
gameCat.options[i].className = 'hot-games';
}
}
new Option(text, value)第一个参数为显示的文字,第二个为value值,如果想设置其他属性需要单独操作。
第二种方案,通过document.createElement()来创建选项,然后再设置选项的属性。在这里w3c标准是可以设置option的 label属性即为显示文本,但事实证明FF并不支持,只是给option增加了一个label属性。而w3c中定义的readonly的属性text,在FF中却可以设置。那么是否需要判断浏览器类型呢?当然不用,该方案代码如下:
for (var i = 0, j = gameOptions.options.length; i < j; i++) {
var option = document.createElement('option');
try{
// 二级DOM中该属性为readonly,但FF确可写,且可显示为选项内容
option.text = gameOptions.options[i].name;
}catch(e){
// IE支持label,可以直接显示为选项的文字
option.label = gameOptions.options[i].name;
}
option.value = gameOptions.options[i].value;
option.className = (gameOptions.options[i].isHot == 'true') ? 'hot-games' : '';
// 如果不传第二个参数,FF下会报错
gameCat.add(option, null);
}
这里要注意的add()函数的第二个参数,该参数为before,可以指定选项插到哪个选项之前,如果为null则插到最后。如果不指定这个参数在IE系不会有问题,FF下会报错,提示Not enough arguments,参数不足,所以最好传个null先。
第三种方案,比较少用于select元素上,IE下是无效的,但是动态添加其他元素的孩子时经常用到。当然也可以设置元素属性后 appendChild(),同方案二。这里要先把select隐藏掉,这样可以减少浏览器重绘次数,对于display='none'的元素的操作不会引起重绘或回流。再改变完之后再显示出来:
// IE无效,FF可用
gameCat.style.display = 'none';
for (var i = 0, j = gameOptions.options.length; i < j; i++) {
var isHot = (gameOptions.options[i].isHot == 'true') ? ' ' : '';
gameCat.innerHTML += '<option value='+gameOptions.options[i].value+isHot+'>'+gameOptions.options[i].name+'</option>';
}
gameCat.style.display = 'block';
这三种方式最常用的就是第一种了,没有兼容性问题,其他两种只是在此作为例子,展示创建option的方法。
转自:http://www.cnblogs.com/jiguang/articles/1894642.html
转载于:https://www.cnblogs.com/johnwonder/archive/2011/03/19/1988784.html
js动态添加options(转载)相关推荐
- JS 对select动态添加options操作[IEFireFox兼容]
JS 对select动态添加options操作[IE&FireFox兼容] 做一个项目,遇到了要动态调整 select 选项的情况,就baidu了一下,发现了一篇与本文同名的帖子. 但是呢,那 ...
- 【原生js】js动态添加dom,如何绑定事件
首先要明白浏览器在加载页面的时候是按顺序来加载的,这样以来就很清楚了,js动态添加dom以后,这些dom并没有绑定事件,这个时候最简单的一个办法就是:将绑定事件的方法封装到一个函数A中,在动态添加完d ...
- form表单 无法提交js动态添加的表单元素问题。。
第一种情况, 这种情况js动态添加的表单元素是不能提交到服务器端的 <table> <form method="post" action=" url ...
- MUI 里js动态添加数字输入框后,增加、减少按钮无效
https://www.cnblogs.com/ssjf/p/10193652.html numbox 的自动初化是在 mui.ready 时完成的 mui 页面默认会自动初始化页面中的所有数字输入框 ...
- js 动态 添加 tabel 表格
js 动态 添加 tabel 表格 代码 <!DOCTYPE html> <html><head><title> new document </t ...
- 原生js动态为table追加html,JS动态添加Table的TR,TD实现方法
本文实例讲述了JS动态添加Table的TR,TD实现方法.分享给大家供大家参考.具体实现方法如下: var tempRow=0; var maxRows=0; function insertRows( ...
- layui upload.render上传组件js动态添加html后再次渲染
页面效果 页面代码: <!-- 轮播图 --><input type="hidden" name="mcBaunell" id="m ...
- html中列表前面的序号带圆圈,js动态添加带圆圈序号列表方法
js动态添加带圆圈序号列表方法 发布时间:2021-02-19 11:30:34 来源:亿速云 阅读:69 作者:小新 这篇文章给大家分享的是有关js动态添加带圆圈序号列表方法的内容.小编觉得挺实用的 ...
- js动态添加样式和jQuery动态添加样式
0.style方式添加样式 DOM对象.style.color = 'red'DOM对象.style.display = 'block/none' //让元素显示/隐藏 1.js动态添加样式 1.添加 ...
最新文章
- 不装.net Framework 也能运行WinForm程序,用飞信(转)
- insert into value与insert into select from dual
- java vnc_linux下配置vnc的方法
- POJ 3126-Prime Path
- MySQL的MVCC底层原理
- 比特币被盗事件频发,这次是 6300 万美元
- Ubuntu18 安装yum
- 2016届毕业生-毕业设计的相关事项
- Swift中字典解析后的问题,!?两种拆包的差别
- albian开发笔记四
- ubuntu20.4安装 mariadb 最新版
- 电脑连接Wifi,只能上QQ不能上网。关键字:无Internet访问权限。
- 胎压检测c语言pta,汽车胎压检测系统的设计与实现
- python chardet_chardet
- 装甲逆袭-NPC对话处理
- 云原生应用负载均衡系列 (2): 入口流量分发、容错与高可用调度
- spin_lock 自旋锁
- 基于java的坦克大战游戏系统毕业设计-5.0(论文设计+源码+PPT答辩).rar
- docker安装elasticsearch内存修改
- Java面试专业技能怎么写_Java面试——专业技能
热门文章
- sql 整改措施 注入_SQL注入入侵防范措施
- ltrim函数_MySQL|trim() 函数用法
- PHP笔记-所有错误统一输出404页面(详细错误日志输出,提高安全性)
- Spring Boot笔记-WebSocket的使用
- Qt文档阅读笔记-QNetworkAccessManager官方解析与实例
- Python工作笔记-dictionary的遍历以及enumerate使用以及Py3中has_key的替代
- Linux学习笔记-Makefile中的变量及函数
- onedrive电脑手机不同步_免费的手机电脑同步便签软件怎么找?求帮忙推荐
- 计算机应用技术自创ppt,教师必备:超好用的课件制作工具
- java 0xf0_java 中类似js encodeURIComponent 函数的实现案例