网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网页制作 > Javascript
网页制作:Dreamweaver教程,FrontPages教程,Javascript教程,HTML教程,CSS教程,心得技巧,DHTML教程,网页特效,Discuz!论坛
本月文章推荐
.javascript分页.
.通过JAVAScript实现页面自适应.
.使用div仿javascript模态窗口.
.用JavaScript实现浏览器地震效果.
.网站论坛注册中常用的一种倒记时.
.Javascript模拟的DOS窗口.
.URL编码转换,escape() encodeURI.
.Javascript模拟游戏中的弹出菜单.
.JavaScript拖放效果分析.
.悟透JavaScript.
.使用JavaScript检测浏览器的相关.
.javascript操作dom的一些函数.
.一段貌似简单的JavaScript.
.javascript单元测试(Jsunit应用) .
.JavaScript通过Flash保存本地数据.
.Javascript实例教程(20) OLE Aut.
.javascript弹出窗口问题总结.
.根据分辨率不同调用不同的css文件.
.javascript对象与数组的例子.
.js实现字体渐渐消失.

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

发表日期:2008-8-28


问题描述

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

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

浏览器兼容


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

               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)这种简洁的方式来编程了,我还没有写,所以不能给出代码了。

上一篇:javascript eval() 人气:1053
下一篇:悟透JavaScript 人气:1249
浏览全部javascript的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐