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

前端之家收集整理的这篇文章主要介绍了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.

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

猜你在找的jQuery相关文章