js数据类型和数组判断

JS数据类型与数组判断

js六大数据类型:number、string、object、Boolean、null、undefined

string: 由单引号或双引号来说明,如"string"

number:什么整数啊浮点数啊都叫数字,你懂的~

Boolean: 就是true和false啦

undefined:未定义,就是你创建一个变量后却没给它赋值~

null: 故名思久,null就是没有,什么也不表示

object: 这个我也很难解释的说。就是除了上面五种之外的类型

 

--------------------上面的都是浮云,下面的才是神马------------------------------

数据类型判断之 typeof

typeof可以解决大部分的数据类型判断,是一个一元运算,放在一个运算值之前,其返回值为一个字符串,该字符串说明运算数的类型,所以判断某个是否为String类型,可以直接 if(typeof(你的值) == "string"){}

以下是各种数据类型返回结果:

复制代码
var a="string"; console.log(a); //string
var a=1; console.log(a); //number
var a=false; console.log(a); //boolean
var a; console.log(typeof a); //undfined

var a = null; console.log(typeof a); //object
var a = document; console.log(typeof a); //object
var a = []; console.log(a); //object

var a = function(){}; console.log(typeof a) //function   除了可以判断数据类型还可以判断function类型
复制代码

这样一来就很明显了,除了前四个类型外,null、对象、数组返回的都是object类型;

对于函数类型返回的则是function,再比如typeof(Date),typeof(eval)等。

然后这里就可以再引申出另一个灰常热门并且解决方法已普遍存在的问题,如何判断数据是个数组类型?

---------------------------------------其实这才是我的目的,咩~----------------------------------------------

js判断数组类型的方法

 方法一之 instanceof

instance,故名思义,实例,例子,所以instanceof 用于判断一个变量是否某个对象的实例,是一个三目运算式---和typeof最实质上的区别

a instanceof b?alert("true"):alert("false")  //注意b值是你想要判断的那种数据类型,不是一个字符串,比如Array

举个栗子:

var a=[];
console.log(a instanceof Array) //返回true 

方法二之 constructor

在W3C定义中的定义:constructor 属性返回对创建此对象的数组函数的引用

就是返回对象相对应的构造函数。从定义上来说跟instanceof不太一致,但效果都是一样的

如: (a instanceof Array)   //a是否Array的实例?true or false

   (a.constructor == Array)  // a实例所对应的构造函数是否为Array? true or false

举个栗子:

复制代码
function employee(name,job,born){
    this.name=name;
    this.job=job;
    this.born=born;
}

var bill=new employee("Bill Gates","Engineer",1985);
console.log(bill.constructor); //输出function employee(name, jobtitle, born){this.name = name; this.jobtitle = job; this.born = born;}
复制代码

那么判断各种类型的方法就是:

console.log([].constructor == Array);
console.log({}.constructor == Object);
console.log("string".constructor == String);
console.log((123).constructor == Number);
console.log(true.constructor == Boolean);

 

-------------------------------------以下不是原创--------------------------------------

较为严谨并且通用的方法:

function isArray(object){
    return object && typeof object==='object' &&
            Array == object.constructor;
}

!!注意:

使用instaceof和construcor,被判断的array必须是在当前页面声明的!比如,一个页面(父页面)有一个框架,框架中引用了一个页面(子页面),在子页面中声明了一个array,并将其赋值给父页面的一个变量,这时判断该变量,Array == object.constructor;会返回false;
原因:
1、array属于引用型数据,在传递过程中,仅仅是引用地址的传递。
2、每个页面的Array原生对象所引用的地址是不一样的,在子页面声明的array,所对应的构造函数,是子页面的Array对象;父页面来进行判断,使用的Array并不等于子页面的Array;切记,不然很难跟踪问题!

方法三之 特性判断法

以上方法均有一定的缺陷,但要相信人民大众的智慧是无所不能及的,我们可根据数组的一些特性来判断其类型 

复制代码
function isArray(object){
    return  object && typeof object==='object' &&    
            typeof object.length==='number' &&  
            typeof object.splice==='function' &&    
             //判断length属性是否是可枚举的 对于数组 将得到false  
            !(object.propertyIsEnumerable('length'));
}
复制代码

有length和splice并不一定是数组,因为可以为对象添加属性,而不能枚举length属性,才是最重要的判断因子。

ps: 在这里普及下 propertyIsEnumerable 方法:

object. propertyIsEnumerable(proName)

判断指定的属性是否可列举

备注:如果 proName 存在于 object 中且可以使用一个 For…In 循环穷举出来,那么 propertyIsEnumerable 属性返回 true。如果 object 不具有所指定的属性或者所指定的属性不是可列举的,那么 propertyIsEnumerable 属性返回 false。

propertyIsEnumerable 属性不考虑原型链中的对象。

示例:

var a = new Array("apple", "banana", "cactus");
document.write(a.propertyIsEnumerable(1));

方法四之 最简单的方法

 对于这种方法,以下有几个链接可供参考解释:

http://blog.youkuaiyun.com/zhangw428/article/details/4171630

http://my.oschina.net/sfm/blog/33197

http://openxtiger.iteye.com/blog/1893378

function isArray(o) {
    return Object.prototype.toString.call(o) === ‘[object Array]‘;
}

 


本文来源于:http://www.cnblogs.com/mofish/p/3388427.html

当然,你知道啦,这篇东西不完全是出自我手的啦,所以参考文章还是要列一列的啦:

http://www.2fz1.com/?p=277

http://msdn.microsoft.com/zh-tw/library/adebfyya.aspx

http://blog.sina.com.cn/s/blog_532751d90100iv1r.html


<think> 首先,用户的问题是基于提供的引用内容:“我想查找在鸿蒙系统的JS环境中判断数据类型是否为数组的方法 请问鸿蒙系统JS环境下判断数据类型数组的方法”。 我需要参考用户提供的引用内容,这些引用是关于鸿蒙系统的JavaScript框架的: - 引用[1]: 描述了鸿蒙JS框架的基本结构,示例代码显示它是零依赖的。 - 引用[2]: 讨论了在JS中检测数据类型的四种方式:typeof、instanceof、constructor、Object.prototype.toString.call()。特别提到typeof的局限性,比如typeof null返回"object",并且无法区分对象类型。 - 引用[3]: 讲解了数组的length属性数组操作,包括遍历多维数组。 - 引用[4]: 展示了对象数组的使用在鸿蒙中的代码示例。 - 引用[5]: 简要提到鸿蒙系统中的JS开发框架。 关键是引用[2],因为它直接讨论了判断JavaScript数据类型的四种方法。用户的问题是判断数据类型是否为数组,所以这与引用[2]高度相关。 从引用[2]中: - 它列出了四种检测数据类型的方式:typeof、instanceof、constructor、Object.prototype.toString.call()。 - 特别说明typeof无法区分数组对象,因为typeof数组返回"object"。 - 实例中提到了instanceofconstructor。 - 还提到Object.prototype.toString.call()可以更精确地判断类型。 所以,在鸿蒙系统的JS环境中,判断数据类型是否为数组,应该使用这些标准JavaScript方法,因为鸿蒙JS框架是基于JavaScript的,兼容标准语法。 具体方法: 1. **使用Array.isArray()**:这是现代JavaScript中推荐的方法来检查是否为数组。Array.isArray(value) 返回true如果value数组。 虽然引用中没有直接提到Array.isArray(),但它是标准方法,应该在鸿蒙环境中支持,因为鸿蒙JS框架声称是零依赖并兼容JavaScript。 2. **使用instanceof**:value instanceof Array。 引用[2]提到instanceof作为检测数据类型的方式之一。 3. **使用Object.prototype.toString.call()**:Object.prototype.toString.call(value) === '[object Array]'。 引用[2]明确说这是第四种方式,可以返回精确的类型。 4. **constructor**:value.constructor === Array。 引用[2]也提到了constructor。 鉴于引用[2]强调typeof的不足,我应该推荐Array.isArray()或Object.prototype.toString.call(),因为这些更可靠。 用户指定了“鸿蒙系统的JS环境”,所以我的回答应该基于鸿蒙的上下文,但从引用看,鸿蒙JS框架支持标准JavaScript语法,因此方法应该相同。 回答结构: - 系统级指令要求:使用中文回答,结构清晰,逐步解决问题。LaTeX数学表达式用$...$,独立公式用$$...$$(但这里可能不需要数学公式)。生成相关问题。添加引用标识。 - 回答中需要自然地添加引用标识,例如[^2]。 回答内容: 1. 介绍在JavaScript中判断数组的常用方法。 2. 解释为什么typeof不适合。 3. 推荐在鸿蒙JS环境中的最佳方法。 4. 基于引用内容,引用[^2]讨论数据类型检测。 5. 生成相关问题。 步骤: - 第一步:确认问题,用户想知道在鸿蒙JS环境中判断数据类型是否为数组。 - 第二步:解释标准JavaScript方法。 - 第三步:应用到鸿蒙上下文。 - 第四步:提供示例代码。 - 第五步:生成相关问题。 示例代码应该使用引用中的格式,比如在代码块中。 从引用[3][4],有数组相关的代码,可以借鉴。 最终回答: - 主体:描述方法。 - 代码示例:展示如何使用不同方法。 - 引用:添加[^2]到相关部分。 生成相关问题:例如,"鸿蒙JS中还有哪些常见的数据类型检测方法?" 或其他相关问题。 </think> ### 鸿蒙系统JS环境下判断数据类型是否为数组的方法 在鸿蒙系统的JavaScript(JS)环境中,判断数据类型是否为数组的方法与标准JavaScript一致,因为鸿蒙JS框架是零依赖的,兼容ECMAScript规范(开发打包后不依赖npm包)[^1][^5]。基于引用内容,鸿蒙JS框架支持所有标准JS数据类型检测机制。下面我将逐步解释推荐方法、原因示例代码,确保回答可靠并基于引用源。 #### 1. **为什么`typeof`不适合判断数组?** - 在JS中,`typeof`操作符用于检测基本数据类型(如`'number'`、`'string'`等),但对于数组,它会返回`'object'`,这与普通对象、null等混淆[^2]。 - 引用[^2]明确指出:`typeof`无法区分数组对象(如`typeof [] === 'object'`),因为其底层二进制编码机制存在局限性(null也被错误识别为对象)。因此,在鸿蒙JS中,**不应依赖`typeof`判断数组**。 #### 2. **推荐方法:使用`Array.isArray()`** - **方法概述**:`Array.isArray(value)`是ECMAScript 5引入的标准方法,直接返回布尔值(`true`表示value数组)。这是最简单、最可靠的方式,鸿蒙JS环境完全支持[^1][^2][^5]。 - **原因**:它在性能安全上优于其他方法(如避免原型链问题),且鸿蒙JS框架在编译后保持原生JS兼容性[^1][^5]。 - **示例代码**: ```javascript // 在鸿蒙JS判断数组 const arr = [1, 2, 3]; const obj = { key: 'value' }; if (Array.isArray(arr)) { console.log('arr是数组'); // 输出: arr是数组 } if (Array.isArray(obj)) { console.log('obj是数组'); // 不会执行 } ``` #### 3. **备选方法:使用`Object.prototype.toString.call()`** - **方法概述**:调用`Object.prototype.toString.call(value)`返回一个字符串,如`'[object Array]'`,可用于精确判断类型[^2]。 - **原因**:引用[^2]将此列为四种数据类型检测方式之一,它能区分数组、对象等复杂类型。在鸿蒙JS环境中,这是可靠备选方案,尤其在不支持`Array.isArray()`的旧版JS中(但鸿蒙通常支持现代规范)[^2]。 - **示例代码**: ```javascript // 使用Object.prototype.toString.call()判断数组 const arr = ['a', 'b']; const result = Object.prototype.toString.call(arr) === '[object Array]'; console.log(result); // 输出: true ``` #### 4. **其他方法(不推荐)** - **`instanceof Array`**: - 使用`value instanceof Array`,但可能受跨框架影响(如iframe环境),可靠性较低[^2]。 - 示例:`console.log([] instanceof Array); // true`。 - **`constructor`属性**: - 使用`value.constructor === Array`,但易被修改导致错误[^2]。 - 示例:`console.log([].constructor === Array); // true`。 - **总结**:在鸿蒙JS中,优先使用`Array.isArray()`或`Object.prototype.toString.call()`,避免`typeof`、`instanceof``constructor`的潜在问题[^2]。 #### 注意事项 - 鸿蒙JS框架在开发时使用npm包编译,但运行时代码无依赖,因此这些方法是纯粹的原生JS,兼容鸿蒙环境[^1][^5]。 - 实际开发中,结合数组操作(如length属性、遍历方法)进行验证,如引用[^3][^4]所示。 如果仍有疑问,建议查阅鸿蒙官方JS文档或调试代码确认类型检测行为[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值