zoukankan      html  css  js  c++  java
  • JS对select动态添加options操作(主流浏览器兼容)

      之前项目中,遇到一个表单提交的页面,里面有多级下拉框联动的复杂逻辑,因此当时在做的过程中也是学到了不少容易出现问题的地方,下面就整理下当时遇到的一些关于下拉框的操作,并指出其中的一些注意点和坑:

    有如下的下拉框:

    <select id="ddlResourceType" onchange="getvalue(this)"> 
    </select> 

    1、动态删除select中的所有options:

    document.getElementById("ddlResourceType").options.length=0;

    2、动态删除select中的某一项option:

    document.getElementById("ddlResourceType").options.remove(index); 

    3、动态添加select中的项option: 

    document.getElementById("ddlResourceType").options.add(new Option(text,value)); 

    上面的操作在IE和火狐中都能测试成功,其实用标准的DOM操作也可以,就是document.createElement,appendChild,removeChild之类的。

    4、下面要说下在取值方面,自己遇到的一个坑,很隐藏的坑,大家都知道,如何获取选中的某一项option的值,当初在用chrome调试的时候,打印出了原生select对象,找到了selectedOptions这个选中项的数组属性,正常情况下,单选下拉框的该属性只有一个值,默认可以使用selectedOptions[0]这样的方式去获取,是的,我当时就是这样去弄的,结果项目上线后大概将近半个月的时候,运营那边报告说,客户在IE浏览器下,下拉框没有数据显示,我当时就想,下拉框动态获取的数据肯定是取数据的时候,出现错误了,然后逐一去排查,发现报错的原因是ie下面select原生对象里,是没有selectedOptions这样的属性的,那么只能另辟蹊径来解决了,我仔细找了下剩余的一些属性,发现  找到了 selctedIndex这样的一个好属性,一看字面意思就明白了,就是选中项的index值啊,这就好办了啊,直接用options[selectedIndex]去访问不就好了么,到此,问题顺利解决:

    取值的时候,应该这样做,才能保证兼容性:

    function getvalue(obj) 
        { 
            var m=obj.options[obj.selectedIndex].value 
            alert(m);//获取value 
            var n=obj.options[obj.selectedIndex].text 
            alert(n);//获取文本 
        }

    5、 检测是否有选中

    if (objSelect.selectedIndex > - 1 ) { 
    // 说明选中 
    } else { 
    // 说明没有选中 
    } 

    6、删除被选中的项 

    objSelect.options[objSelect.selectedIndex] = null ; 

    7、增加项

    objSelect.options[objSelect.length] = new Option( " 你好 " , " hello " ); 

    8、修改所选择中的项

    objSelect.options[objSelect.selectedIndex] = new Option( " 你好 " , " hello " );

    9、得到所选择项的文本

    objSelect.options[objSelect.selectedIndex].text; 

    10、得到所选择项的值

    objSelect.options[objSelect.selectedIndex].value;

    纸上得来终觉浅,绝知此事要躬行。必须要去尝试,在实践中,才能获得解决问题的最有效的途径,这也是让记忆深刻的唯一方式,共勉。

  • 相关阅读:
    小端字节序与大端字节序
    V8引擎的垃圾回收策略
    TTL 和 DNS TTL 的区别
    详解 undefined 与 null 的区别
    Node.js 事件循环机制
    requestAnimationFrame 知多少?
    Web前端知识体系精简
    Vue.js 和 MVVM 小细节
    使用 Node.js 搭建 Web 服务器
    H5单页面手势滑屏切换原理
  • 原文地址:https://www.cnblogs.com/bettermu/p/8434140.html
Copyright © 2011-2022 走看看