博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
IE7中使用Jquery动态操作name问题
阅读量:6507 次
发布时间:2019-06-24

本文共 1133 字,大约阅读时间需要 3 分钟。

  • 问题:IE7中无法使用Jquery动态操作页面元素的name属性。

在项目中有出现问题,某些客户的机器偶尔会有,后台取不到前台的数据值。

然开发和测试环境总是不能重现问题。坑爹之处就在于此,不能重现就不能调试,就不能知道改了后还会不会有这样的问题。

想想可能与客户环境唯一不同就只有可能是js缓存问题了,然后把所有的js文件引用的地方都加上一个当前时间参数,然问题依然存在。

本来规定的版本就是IE8,所以也没有想过会有版本兼容问题,在说了咱用的是jquery,jqeruy的出现不就是号称为了解决浏览器的兼容问题么。

该死了问题,还真实版本问题。因为某些页面需要用到IE8的兼容模式,然兼容模式其实就是像下兼容,那不就是兼容IE7 了么?

  • 于是本地用demo测试了下。

IE8:  ok!

IE8兼容模式:

??为什么 $("#input").attr("name")取到的是修改后的值,而$("#div").html() 取到的name还是原先的值??

F12查看生成的html

擦 submitName 是什么东东?明显name没有改变。submitName 应该是jquery生成的 然后读取name的时候 也是直接读取的submitName 的值。

为什么$("#div").html() 取的值中没有submitName 呢??  我也不知道jquery中的html方法是怎么实现的~~

 

 

项目中的实现方式类似于:

 

这样  在IE8和谷歌浏览器 取值正常,在IE8兼容模式却取不到值。【不要问为什么非要这么赋值取值,这是demo'类似于'的实现,且是一个框架】

 

解决方案:

1.直接用jquery修改name 然后访问name是ok的,虽然 中间是生成了submitName 。

2.可以先$("#div2").html($("#div").html()); 然后在修改.attr("name", "myname");

3.可以直接拼接html。    $("#div").html("<input id="input" name="myname" value="123" type="text" />")

 

最后百度了下,原来是IE7不能用document.getElementsByName()访问js动态创建和修改后的name值。

 

转载地址:http://edwfo.baihongyu.com/

你可能感兴趣的文章
if(A && B || C),应该如何解释满足A、B、C之间的关系
查看>>
为什么IO多路复用需要采用非阻塞式IO
查看>>
Handover
查看>>
视频播放插件Video.js
查看>>
NuGet学习笔记(1)——初识NuGet及快速安装使用
查看>>
python生成器
查看>>
Spring session redis ERR unknown command 'CONFIG'
查看>>
兄弟选择器 + 和 ~
查看>>
git pull远程所有分支
查看>>
TextInputLayout 和 TextInputEditText 的简单介绍以及使用
查看>>
发个WP7官方教程<<四天玩转 Windows Phone 开发>> 下载地址.
查看>>
第一篇博客,随笔留念
查看>>
Mysql几种索引类型的区别及适用情况
查看>>
C#操作DataTable类
查看>>
【spring】IllegalArgumentException Can not set field to $Proxy 在spring中使用事物或AOP遇到的错误...
查看>>
定时器
查看>>
ffmpeg获取视频封面图片
查看>>
干净的架构The Clean Architecture_软件架构系列
查看>>
从房地产住宅销售面积增速看房地产行业
查看>>
poj 1661 Help Jimmy (动态规划)
查看>>