javascript – 在本机iPhone应用程序中的UIWebView内部是否存在使用InnerHTML的错误?

前端之家收集整理的这篇文章主要介绍了javascript – 在本机iPhone应用程序中的UIWebView内部是否存在使用InnerHTML的错误?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个相当大的 HTML / JS / CSS应用程序,在iPhone上作为一个Web应用程序运行Safari时,效果很好.

当在本机iPhone应用程序中的UIWebView中运行相同的应用程序时,jQuery内的调用以创建HTML片段默认地失败(即:$(“< div> HELLO WORLD< / div>”))不会创建元素.

我已经跟踪到以下等效的代码片段,在干净的jQuery方法中:

var div = document.createElement(“div”);
div.innerHTML =“< div> HELLO WORLD< / div>”;

当我看到div.outerHTML我看到
< DIV> /< DIV>

div.innerHTML返回一个空字符串.

这似乎不是一个jQuery问题,100%的时间也不会发生.我找不到一个模式,但在某些情况下,它连续工作2-3次,有时连续5-6次失败.这似乎只在Objective-C应用程序中的UIWebView内运行应用程序时显示.此外,我只在运行iOS 4.2的实际设备上看到,而不是模拟器.

有没有人碰到任何类似的东西?有谁有修复?

解决方法

我也有这个问题.当手机的cpu很忙(说100%)时就会发生这种情况.然后渲染引擎有时会忘记innerHTML设置.

我的unify project中包含的解决方案是测试childNodes中是否有元素,否则再次应用.

var target = document.createElement("div");
var text = "<div>Hello World</div>";
target.innerHTML = text;
var self = this;
self.__intervalHandle = window.setInterval(function() {
  target.innerHTML = text:
  if (target.firstChild) {
    window.clearInterval(self.__intervalHandle);
    self.__intervalHandle = null;
  }
},100);

这迫使渲染引擎将innerHTML应用于DOM,并给予渲染引擎一些时间(在本例中为100 ms,在我们的测试中是一个很好的值)来处理它.

猜你在找的JavaScript相关文章