通过js的innerhtml来获取一个dom节点,内部的html值时,如果属性值没有空格,则ie左右版本下,都会出现标签大些,双引号丢失问题。如果属性值有空格,则标签会变成大写,引号则正常输出.

当属性值无空格时:
FF3.5.7(gecko/20091221)<div ></DIV>

产生这个BUG的原因是什么呢?

When you get the innerHTML of a DOM node in IE, if there are no spaces in an attribute value, IE will remove the quotes around it.IE's innerHTML doesn't remove quotes from non standard attributes.

即使是jQuery里面,jquery团队的技术人员也没有解决这个问题.

提供下解决方案:

 

    function ieInnerHTML(obj) { 
         var zz = obj.innerHTML, 
             z =  
           zz.match(/<\/?\w+((\s+\w+(\s*=\s*(?:".*?"|'.*?'|[^'">\s]+))?)+\s*|\s*)\/?>/g); 
          if (z){ 
            for (var i=0;i<z.length;i++){ 
              var y, zSaved = z[i]; 
              z[i] = z[i].replace(/(<?\w+)|(<\/?\w+)\s/, 
                                  function(a){return a.toLowerCase();}); 
              y = z[i].match(/\=\w+[?\s+|?>]/g); 
               if (y){ 
                for (var j=0;j<y.length;j++){ 
                  z[i] = z[i].replace(y[j],y[j] 
                             .replace(/\=(\w+)([?\s+|?>])/g,'="$1"$2')); 
                } 
               } 
               zz = zz.replace(zSaved,z[i]); 
             } 
           } 
          return zz; 
         } 

 在相应的地方调用函数ieInnerHTML

  if(/*@cc_on!@*/0){ 

      inner_str = ieInnerHTML(obj);

  }else

      inner_str = obj.innerHTML;

  }


原理:对IE版本进行对应的JS处理,而且相应的元素标签中不要出现非标准元素


参考资料:

  1. innerHTML removes attribute quotes in Internet Explorer
  2. innerHTML中的双引号哪去了?



本文引用:http://liupeng.us/how-to-fix-js-innerhtml-double-quotes/

 

相关文章:

  • 2021-12-02
  • 2021-10-20
  • 2022-12-23
  • 2021-09-30
  • 2021-05-29
  • 2021-06-08
猜你喜欢
  • 2022-01-03
  • 2022-01-22
  • 2021-11-24
  • 2021-12-30
  • 2022-12-23
  • 2021-10-12
  • 2021-12-23
相关资源
相似解决方案