博客园闪存分页是用JavaScript生成的,今天发现在IE8下点击页码不能翻页,翻页操作是在当前页码的onclick事件中进行的。
开始代码是这么写的:
var a = document.createElement("a"); a.setAttribute("onclick", this.ClickFunctionName + "(" + pageIndex + ");Pager.SetCurrent(" + pageIndex + ");");
由于IE8不支持setAttribute方法,这里添加的onclick事件处理程序并未添加上。
后来改为jQuery的attr方法:
$(a).attr("onclick", this.ClickFunctionName + "(" + pageIndex + ");Pager.SetCurrent(" + pageIndex + ");");
这样虽然添加上去了,但不管怎么点击,onclick事件处理程序就是不执行,Chrome与Firefox都没这个问题。
最终通过下面的代码解决了问题:
var js = this.ClickFunctionName + "(" + pageIndex + ");Pager.SetCurrent(" + pageIndex + ");"; a.onclick = function() { eval(js); }
本文探讨了在IE8浏览器中使用JavaScript实现翻页功能遇到的问题及解决方案。初始使用document.createElement结合setAttribute方法设置翻页按钮的onclick属性失败,改用jQuery的attr方法同样无效。最终通过直接赋值onclick属性并使用eval执行字符串内的JavaScript代码成功解决。
261

被折叠的 条评论
为什么被折叠?



