zoukankan      html  css  js  c++  java
  • 火狐不支持innerText的解决办法

    例:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>dance styles</title>
    </head>
    
    <body>
    <div >
    <p>
    Dance Styles (choose)
    <input type="text" name="Dance Styles" id="DanceStyles" style="255px;" /></p>
    <div class="choose">
      <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer;">Ballet</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Contemporar</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Jazz</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Street Jazz</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Hip Hop</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Tap</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Ballroom</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Latin</a></p>
    <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer">Belly</a></p>
    </div>
    </div>
    </body>
    </html>

    以上这个采用了innerText来获取文字的代码,在火狐中是失效的。

    但是如果加上一段JavaScript:

    <script type="text/javascript">
    function innerText(node){//返回的是数组类型
                    var innerTextArr = [];
                    var root = document.getElementById(node);
                    var getChild = function(node){
                            var childs = node.childNodes;
                            for(var i=0;i<childs.length;i++)
                                    if(childs[i].nodeType == 3)
                                            innerTextArr.push(childs[i].nodeValue);
                                    else if(childs[i].nodeType == 1){
                                            getChild(childs[i]);
                                    }
                    }
                    getChild(root);
                    return innerTextArr;
            }
    </script>

    就使得innerText也起作用了。

    还有一个同样功效用来支持outerHTML的JS函数:

    View Code
    function outerHTML(node){//返回的是字符串类型
                                    var tag = document.getElementById(node).tagName;
                                    var outerHTMLStr = "<" + tag.toLowerCase();
                                    var atts = document.getElementById(node).attributes;
                                    for(var i = 0;i<atts.length;i++)
                                                    outerHTMLStr += " " + atts[i].name + "=\"" + atts[i].value + "\"";
                                    outerHTMLStr += ">";
                                    outerHTMLStr += document.getElementById(node).innerHTML;
                                    outerHTMLStr += "<" + tag.toLowerCase() + ">"
                                    return outerHTMLStr;
                    }

    否则的话,只要把所有的innerText都换成innerHTML就可以直接让火狐支持,而不需要额外的函数。

    像这样:

    <div >
    <p>
    Dance Styles (choose)
    <input type="text" name="Dance Styles" id="DanceStyles" style="255px;" /></p>
    <div class="choose">
      <p><a onclick= "DanceStyles.value=innerText " style=" cursor:pointer;">Ballet</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Contemporar</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Jazz</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Street Jazz</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Hip Hop</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Tap</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Ballroom</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Latin</a></p>
    <p><a onclick= "DanceStyles.value=innerHTML " style=" cursor:pointer">Belly</a></p>
    </div>
    </div>
  • 相关阅读:
    rsyslogd 日志服务
    Java PropertiesLoader 工具类 开发者使用
    1k纯JS脚本的3D玫瑰
    Python ConfigParser的使用
    一些比较精妙的宏定义
    关于realloc的调整内存方式
    初学javascript代码
    PHP中this,self,parent的区别
    PHP数据库操作基类(单例模式)
    php之规范编程命名
  • 原文地址:https://www.cnblogs.com/haimingpro/p/2673270.html
Copyright © 2011-2022 走看看