给select控件在指定位置插入option(javascript)

2016-02-19 16:17 124 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享给select控件在指定位置插入option(javascript)的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - Web开发 】

问题描述

      对于select控件 1 2 3,我们可以通过它的options.add(new Option(v,t))的方法动态的插入一个option选项,但是新增的option的位置只能在最后,却不能插入到指定的任意位置。

解决方法

      既然select的options属性提供的方法无法实现上面的需求,那么只好找办法了。我们知道html控件都有一个insertBefore的方法,用以在指定位置插入子控件,这个方法也许可以使用,不妨测试一下,呵呵,真的可以。不过对于IE和firefox,还是有细节的差别。

浏览器兼容

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

    对于FireFox,我们可以直接使用 selectCtl.insertBefore(new Option('value', 'text'), selectCtl.options[i]);这样的简单的形式在制定位置插入option,但是IE好像不行,需要使用下面的形式才可以 

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

               var option = document.createElement("option");

                option.value = 'value';

                option.innerText = 'text';


                selectCtl.insertBefore(option, selectCtl.options[i]);

完整代码(firefox3.01,IE7测试通过)

 function addAt(selectCtl,optionValue,optionText,position)

{

   var userAgent = window.navigator.userAgent;

   if (userAgent.indexOf("MSIE") 0) {
                var option = document.createElement("option");
                option.value = optionValue;
                option.innerText = optionText;
                selectCtl.insertBefore(option, selectCtl.options[position]);
            }
            else
                selectCtl.insertBefore(new Option(optionValue, optionText), selectCtl.options[position]);

}

更好的方法

   上面使用增加一个新的javascript函数来解决问题, 我们还可以通过javascript中的prototype属性来完成,这样就可以给select控件增加一个新的扩展方法addOptionAt,使用 selectCtl.addOptionAt(new Option('v','t'),position)这种简洁的方式来编程了,我还没有写,所以不能给出代码了。

来源:http://www.tulaoshi.com/n/20160219/1611539.html

延伸阅读
想必大家都有这样的需求,就是在一个很长的Word文档中如何快速定位到指定的位置,这样可以快速的解决问题,不必将时间浪费在寻找上。此需求通过“定位”功能便可轻松实现,打开“查找和替换”对话框也可以使用【Ctrl】+【G】组合快捷键打开该对话框,在右侧“输入页号”文本框中输入想要定位的页码按“定位...
昨天有个朋友问我,怎么样处理重叠的控件,让指定的控件在最上面.我就很抓狂,很奇怪为什么会有这种需求,但昨天上班忙,没时间.今天早上来就写了一段代码试试,如下:SetMeTop是设置最上的函数,button1_Click是一个测试方法,经测试,这样是可行的.为什么要用一个ArrryList而不是直接用index来删除呢,是因为删除上层的一个控件后,会导致下面控件的inde...
符号具有一定的象征意义,让人过目不忘的符号比文字更有亲和力。在PPT中我们可以插入需要的符号,来修饰一些标示性的文字。不仅如此还可以为你的PPT增姿添彩,下面通过一个示例为大家详细讲述下具体的插入过程。 简要概述 首先打开一篇需要插入符号的文档,在“符号”对话框中单击"字体"框右侧的下拉按钮,选择“Wi...
标签: Web开发
我们用Select的onchange事件时,常会遇到这样一个问题,那就是连续选相同一项时,不触发onchange事件.select的onchange事件就是这样子的.你得有Change(改变),才能触发该事件... 掌握了它的特性后,相应的解决办法也很简单. select name=sel onchange="bao(this.options[this.options.selectedIndex].value)" option value=""请选择 opt...
标签: Delphi
  Form中的Select控件不支持对选择项(Option)的排序,下面我将对Option中value属性值进行排序,并调整每个Option排序后的位置,具体代码如下(这里假设每个Option中的value与其中的text内容相同):   该函数运用了Array(数组)对象的排序(sort)方法,实现了Select排序。 function sortMe(oSel){ var ln = oSel.options.le...

经验教程

907

收藏

74
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部