IE8下JQuery clone 出的select元素使用append添加option异常解决记录
遇到一个怪现象,由于配置参数是多实例的, 故采用JQuery对模板HTML代码进行clone,
HTML代码中包括select标签, 在克隆之后需要对select进行添加option。
在firefox和chrome浏览器上都没有问题,在IE10下也没有问题,
但是在IE8下就出现问题,使用append添加option后,IE8上就显示不出来新添加option。
示例代码如下,对于clone出的第二个select有问题,但是通过打印,发现添加后的option数目是正确的3个。
这个就太令人费解了。
<html>
<head>
<script src="./jquery.js"></script>
</head>
<body>
<div name="template">
<select>
</select>
<input type="button" name="testBtn" value="click me">
</div>
<script> $("[name='testBtn']").on("click",function(){
alert("enter")
var temp = $(this).parents("[name='template']");
$("select", temp).empty(); $("select", temp).append("<option value='auto'>auto</option>");
$("select", temp).append("<option value='1'>1</option>");
$("select", temp).append("<option value='2'>2</option>");
alert("option len="+$("option", $("select", temp)).length)
}); $("[name='template']").clone(true).appendTo("body");
</script>
</body>
</html>
点击第二个select,下拉框内容页显示不出来,第一个select是原始select,是没有这个问题的。
细细思讨怀疑可能是clone出来的副本样式渲染上没有更新,
故在select在填充完option后, 主动做一次隐藏后再次显示的动作,select恢复正常。
<html>
<head>
<script src="./jquery.js"></script>
</head>
<body>
<div name="template">
<select>
</select>
<input type="button" name="testBtn" value="click me">
</div>
<script> $("[name='testBtn']").on("click",function(){
alert("enter")
var temp = $(this).parents("[name='template']");
$("select", temp).empty(); $("select", temp).append("<option value='auto'>auto</option>");
$("select", temp).append("<option value='1'>1</option>");
$("select", temp).append("<option value='2'>2</option>");
alert("option len="+$("option", $("select", temp)).length)
$("select", temp).hide().show()
}); $("[name='template']").clone(true).appendTo("body");
</script>
</body>
</html>
但是这种规避方法,似乎也不好,每次给select替换option,都需要隐藏后再显示,给用户视觉带来冲击,控件闪烁,牺牲网页的可访问性(有违WCAG),故寻找其他保持select控件显示不变的方法。
在http://bbs.csdn.net/topics/390559926找到相同问题讨论中的一则说明:
IE 下的 option 不能当普通标签来看,appendChild,innerHTML...都不能用
通过可以 select.options.app( new Option(text,value) )
真是高人,实验了appendChild确实不能添加option,于是借鉴此思路,为了保持JQuery append option string的写法, 即时不改变原有代码,通过新添加一个无用option,然后再删除它,来达到恢复select样式的目的。
示例代码如下:
<html>
<head>
<script src="./jquery.js"></script>
</head>
<body>
<div name="template">
<select>
<option>jj</option>
</select>
<input type="text" value="heeh">
<input type="button" name="testBtn" value="click me">
</div>
<script> $("[name='testBtn']").on("click",function(){
//alert("enter")
var temp = $(this).parents("[name='template']");
$("select", temp).empty(); $("select", temp).append("<option value='auto'>auto</option>");
$("select", temp).append("<option value='1'>1</option>");
$("select", temp).append("<option value='2'>2</option>");
//alert("option len="+$("option", $("select", temp)).length); //$("select", temp).hide().show() var select = document.getElementsByTagName("select")[];
var option = document.createElement("option");
select.add( option );
select.remove(select.length-);
}); $("[name='template']").clone(true).appendTo("body");
$("input[type='text']").eq(1).val("reset")
</script>
</body>
</html>
这种方法也是属于偏的方法,既然怀疑是样式问题,我想还是使用样式的方法来纠正,
使用IE8调试器审查两个select看不出有啥异样,瞎试吧,select是行内元素,display:inline赋值试下果然OK:)
但是第一次OK, 第二次之后还是有问题的,应该是每次给option添加后,需要出发样式的变化,才能解决这个问题,
于是先赋值 inline-block 后改为inline,可以彻底解决这个问题。推荐这个方法。
<html>
<head>
<script src="./jquery.js"></script>
</head>
<body>
<div name="template">
<select>
<option>jj</option>
</select>
<input type="text" value="heeh">
<input type="button" name="testBtn" value="click me">
</div>
<script> $("[name='testBtn']").on("click",function(){
//alert("enter")
var temp = $(this).parents("[name='template']");
$("select", temp).empty(); $("select", temp).append("<option value='auto'>auto</option>");
$("select", temp).append("<option value='1'>1</option>");
$("select", temp).append("<option value='2'>2</option>");
//alert("option len="+$("option", $("select", temp)).length); //$("select", temp).hide().show() /*
var select = document.getElementsByTagName("select")[1];
var option = document.createElement("option");
select.add( option );
select.remove(select.length-1);*/ $("select", temp).css("display", "inline-block");
$("select", temp).css("display", "inline"); }); $("[name='template']").clone(true).appendTo("body");
$("input[type='text']").eq(1).val("reset")
</script>
</body>
</html>
补充一种另外一种解决方法, 不使用向select中append option,
而将select整体替换为 “<select><option></option></select>”, 上代码:
<html>
<head>
<script src="./jquery.js"></script>
</head>
<body>
<div name="template">
<select>
</select>
<input type="button" name="testBtn" value="click me">
</div>
<script> $("[name='testBtn']").on("click",function(){
alert("enter")
var temp = $(this).parents("[name='template']"); var selectStr = "<select>"
+ "<option value='auto'>auto</option>"
+ "<option value='1'>1</option>"
+ "<option value='2'>2</option>"
+ "</select>";
//console.log(selectStr); $(selectStr).replaceAll($("select", temp));
//$("select", temp).replaceWith(selectStr);
alert("option len="+$("option", $("select", temp)).length)
}); $("[name='template']").clone(true).appendTo("body");
</script>
</body>
</html>
与大家分享下吧, 至于JQuery克隆为啥会把select样式弄乱,还请大侠赐教。
IE8下JQuery clone 出的select元素使用append添加option异常解决记录的更多相关文章
- ie8下jquery改变PNG的opacity出现黑边
复制网上的,没有他们那个类型的博客,所以就直接复制了 这些天在做一个效果,鼠标经过,PNG图片由透明变成不透明,jquery代 码:$(element).animate({"opacity& ...
- ie8下jquery改变PNG的opacity出现黑边,ie6下png透明解决办法
目前互联网对于网页效果要求越来越高,不可避免的用到PNG图片,PNG分为几种格 式,PNG8 PNG24 PNG32,其中最常用的,也是显示效果和大小比较适中的则是PNG24,支持半透明,透明,颜色也 ...
- ie8下input文字偏上select文字偏下
1.ie8下input文字偏上 正常情况下input的显示情况如下 当设置input的高度时,就会出现文字不垂直居中偏上的情况,如图 解决方案 强input的行高line-height与其高度设置一致 ...
- ie8下jquery读取当前点击的标签位置错误,原因是里面有内容写了text-indent:-9999px
今天写一地图的效果,鼠标点击对应的区域,弹出所点击区域的名字. 因为设计的区域名字有特殊效果,所以,在点击区域里面套了个标签写上区域名字用来识别,但是这个文字呢不同显示在页面上,所以就给 em 加个了 ...
- jquery 让select元素中的某个option被选中
jquery 操作select 取值,设置选中值 博客分类: javaScript selecttextvalue取值设置选中值 比如 <select class="type" ...
- IE8下jQuery改变png图片透明度时出现的黑边问题
png24格式的图片在用jQuery添加显示隐藏动画时发现,图片的半透明区域出现黑边? 在网上搜了搜主要有以下几种办法: 1.把图片保存成PNG-8格式. 2.把背景色一起切入并保存为JPG格式. 以 ...
- jQuery和js获取select元素的选中项value?
1.jQuery方式获取:$("#test").val(); 2.js方式获取:document.getElementById("test").value;
- document.elementFromPoint在IE8下无法稳定获取当前坐标元素的解决方法
document.elementFromPoint(e.clientX, e.clientY) document.elementFromPoint(e.clientX, e.clientY) 执行2次 ...
- jquery动态出操作select
var citys = {1:'北京',2:'上海',3:'广州',4:'深圳'}; $("#city option:gt(0)").remove(); for(var k in ...
随机推荐
- ACM 懒省事的小明
懒省事的小明 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 小明很想吃果子,正好果园果子熟了.在果园里,小明已经将所有的果子打了下来,而且按果子的不同种 ...
- jS事件:target与currentTarget区别
target在事件流的目标阶段:currentTarget在事件流的捕获,目标及冒泡阶段.只有当事件流处在目标阶段的时候,两个的指向才是一样的, 而当处于捕获和冒泡阶段的时候,target指向被单击的 ...
- 【异常】java.lang.LinkageError: loader constraints violated
[问题背景] 南非客户帐单提醒功能过程中的一个问题,当启动服务器后,后台报java.lang.LinkageError: loader constraints violated when l ...
- 如何更改tableView cell的accessoryView位置,如何让首尾的Separator不显示
一,如何更改tableView cell的accessoryView位置 1.实则是更改不了的,因此右边总会有一个小边距. 2.可以向 cell 的 contentView 中添加按钮放在右边,与 c ...
- 0代码隐藏GroupedTableView上边多余的间隔
0代码隐藏GroupedTableView上边多余的间隔 实现诸如支付宝的 “探索” 页面时,最简单的方案是在 Storyboard 中来一个静态 Grouped UITableViewControl ...
- ELK_elk+redis 搭建日志分析平台
这个是最新的elk+redis搭建日志分析平台,今年时间是2015年9月11日. Elk分别为 elasticsearch,logstash, kibana 官网为:https://www.elast ...
- css解决select下拉表单option高度的办法
css在给select下拉表单设置样式如边框时可以轻松搞定,而我们在不喜欢其默认的下拉箭头的样式时试图通过background:url(图片路径)来修改之,则往往会出现浏览器的兼容性问题,在网上查了好 ...
- [zt] ROI (Region of Interest) 感兴趣区域 OpenCV
在以前介绍IplImage结构的时候,有一个重要的参数——ROI.ROI全称是”Region Of Interest”,即感兴趣的区域.实际上,它是IPL/IPP(这两个是Inter的库)结构IplR ...
- Linux下配置Lamp
linux下配置lamp步骤: 一.快速安装Apache+PHP5+MySql 先更新: # yum update 然后安装LAMP环境:(163的yum源上只有php5.1.6 mysql 5.0. ...
- TestStand与LabVIEW UI 交互
交互起因 客户觉得TestStand界面复杂,希望一个简单的界面即可进行序列执行,采用LabVIEW调用TestStand引擎可实现快速设计,将TestStand拆解到LabVIEW.然而,这样做需要 ...