打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
修正IE下document.getElementsByName无法获取DIV标签

<!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>document.getElementsByName</title>
<style>
div{
    width: 100px;
    height: 100px;
    border:1px solid red;
}
</style>
</head>
<body>
<div name="odiv">div1</div>
<div name="odiv">div2</div>
<div name="odiv">div3</div>
<div name="odiv">div4</div>
<div name="anotherdiv">AnotherDiv</div>
<script type="text/javascript">
<!--
// 可见在IE下通过document.getElementsByName是无法获取DIV标签的,FF可以
//alert(document.getElementsByName("odiv").length); // IE:0 FF:4

// 兼容IE FF的ByName方法
var getElementsByName = function(tag, name){
    var returns = document.getElementsByName(name);
    if(returns.length > 0) return returns;
    returns = new Array();
    var e = document.getElementsByTagName(tag);
    for(var i = 0; i < e.length; i++){
        if(e[i].getAttribute("name") == name){
            returns[returns.length] = e[i];
        }
    }
    return returns;
}
alert(getElementsByName("div","odiv").length); // IE:4 FF:4
//-->
</script>
</body>
</html>

 

原文参看:http://www.cnblogs.com/bluedream2009/archive/2009/07/24/1529799.html

/*------------------针对IE内核的做了下调整---------------------*/

//处理IE下getElementsByName获取DIV内容
    var isOpera, isIE = false;
    if (typeof(window.opera) != 'undefined') {
        isOpera = true;
    }
    if (!isOpera && navigator.userAgent.indexOf('Internet Explorer')) {
        isIE = true
    };
    if (isIE) {
        var getElementsByName = function(tag, name){
            var returns = document.getElementsByName(name);
            if(returns.length > 0) return returns;
            returns = new Array();
            var e = document.getElementsByTagName(tag);
            for(var i = 0; i < e.length; i++){
                if(e[i].getAttribute("name") == name){
                    returns[returns.length] = e[i];
                }
            }
            return returns;
        }
        //alert(getElementsByName("div","mright").length); // IE:4 FF:4
    }


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
javascript 如何正确使用getElementById,getElementsByName(), and getElementsByTagName()
JavaScript仿淘宝智能浮动
DOM - 获取当前样式和IE兼容
js 可行的print
大数据WEB阶段(四)JavaScript
事件冒泡与事件捕获及事件委托
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服