• js中typeof与instanceof用法小记


    因为项目的特殊性需要做ie8兼容,因为引入了下面的js文件

    <script>
        var ie_script=function(src){
            return "<script type="text/javascript" src=""+src+""></script>";
        };
        if(!document.addEventListener){
            document.write(ie_script('http://192.168.77.28:8089/EMS/shanlv/IE8/es5/es5-shim.min.js'));
            document.write(ie_script('http://192.168.77.28:8089/EMS/shanlv/IE8/html5/dist/html5shiv.min.js'));
            document.write(ie_script('http://192.168.77.28:8089/EMS/shanlv/IE8/Respond/dest/respond.min.js'));
             document.write(ie_script('http://192.168.77.28:8089/EMS/shanlv/IE8/pie/PIE.js'));
        }
    </script>

    但是在有ligerui页面的用ie8打开的时候一直报错误,如下

    然后一路狂找原因,最终发现原因是因为页面引入了兼容es5语法的js文件,页面中数组在操作的过程中都会自动的添加了一个function(如下图一)这个过程中本身是没有问题的,但是因为引入的ligerui.all.js中,而ligerui.all.js中遍历数组的时候全部用的是for in的方法,这时候就将数组里面的function也遍历出来,这样的结果就是

    1、导致页面表格渲染问题,无形中多了九行数据

    2、报错(如上图圈中的错误)

    图一

    图二

    所以解决的办法

    在for in遍历的前面加上一段话

    for(var key in obj){
        if(ie8(obj,obj[key])){
            continue;
        }
    }
    function arrayIe8(obj,i){
        if(obj instanceof Array&&typeof i==="function"){
            return true
        }
        return false
    }

    要么就是在页面中不引入兼容es5语法的js

  • 相关阅读:
    MySQL的双主配置
    MySQL主从复制配置部署
    Linux centOS安装MySQL
    hive搜索报错
    常用设计模式
    Cookie禁用 获取session
    排序算法
    MySQL优化
    javascript Map和Set
    ThinkPHP的基本操作
  • 原文地址:https://www.cnblogs.com/pengfei25/p/9482899.html
Copyright © 2020-2023  润新知