jQuery 1.3.2中是否有JQuery(..).html()buggy?

这里的代码不会返回预期的内容
jQuery('<div>Look here: [ jQuery0="null" ]</div>').html()

相反,你得到:

Look here: [ ]

有问题的jQuery源代码

html: function( value ) {
        return value === undefined ?
                (this[0] ?
                        this[0].innerHTML.replace(/ jQuery\d+="(?:\d+|null)"/g,"") :
                        null) :
                this.empty().append( value );
},

.replace背后的动机是什么?我没有时间来讨论jQuery的其余部分,但这样的代码让我想知道我是否应该在生产中使用jQuery.

解决方法

代码是1.3.2中的新代码,不在1.3.1中.在我看来,jQuery使用名称以“jQuery”开头的属性来存储元素上的数据,这是当你要求返回html时不向你公开的方法.

它显然不是一个错误.作者打算在返回字符串之前删除该HTML.

这会影响您的代码吗?与任何库一样,您应该在部署之前彻底测试您的生产代码.

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...