码迷,mamicode.com
首页 > 编程语言 > 详细

javascript是判断对象是否是数组

时间:2016-06-21 12:41:21      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

JS中的数据类型:

2大类
 原始类型:值保存在变量本地的数据类型
  5种:Number String Boolean undefined null
  Number:8bytes 舍入误差-->四舍五入
  String:每个英文字符 1byte
      每个汉字字符 2bytes
      一旦创建内容不可改变
  Boolean: true false
引用类型:值不保存在变量本地的数据类型

  js中的变量 vs 数据库
   内存中    硬盘上的文件
   临时的    持久的
   客户端    服务器端只存一份

一般用typeof判断数据类型:如下>注意最后一个

console.log(typeof("Hello")); //string
console.log(typeof(123)); //number
console.log(typeof({a:1})); //object
console.log(typeof(function f(){})); //function
console.log(typeof([])); //object

为什么不是array呢?该如何判断一个对象是object还是array类型呢?

  typeof可以检测基本类型包括 undefined, string, number, boolean,但是对于检测对象就不靠谱了。

  不只是Array,javascript中的对象,包括 Date, String, Boolean, Number, Object, Function, Array, RegExp, Error 使用typof只会返回 "object"。

下面给出4中方法:

//如果当前浏览器的Array构造函数对象中不包含isArray
    if(!Array.isArray){
    //    为Array构造函数添加isArray方法
        Array.isArray=function(obj){
            //判断obj是不是数组类型4种
            //1. 如果Array.prototype在obj的原型链中
              //return Array.prototype.isPrototypeOf(obj);
            //2. 用instanceof: 语法:obj instanceof 构造函数名
            //return obj instanceof Array;
            //实例:一个构造函数创建出的每个具体对象
            //3. 原型对象的constructor属性
            //return obj.constructor==Array;
            //4. 利用Object原型的toString方法
            /*call,apply
                call,在调用方法的一瞬间更换调用方法的对象*/
            return Object.prototype.toString.apply(obj)=="[object Array]";
        }
    //  
    }

注意:(来自https://segmentfault.com/q/1010000000130605)

使用 instanceof 或者 constructor 来检测 Array 也不是靠谱的办法。

如果是待检测的数组来自一个iframe的数组时,instanceof和contructor都会失效。

由于每个iframe都有一套自己的执行环境,跨frame实例化的对象彼此是不共享原型链的。

var iframe = document.createElement(‘iframe‘);   
  document.body.appendChild(iframe);   
  xArray = window.frames[window.frames.length-1].Array;   
  var arr = new xArray(1,2,3); // [1,2,3]    
  arr instanceof Array; // false    
  arr.constructor === Array; // false

 

javascript是判断对象是否是数组

标签:

原文地址:http://www.cnblogs.com/-walker/p/5603090.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!