区别类型为object的对象、数组和日期

本文介绍JavaScript中使用typeof方法和constructor属性来准确判断变量类型的技巧,包括如何区分对象、数组及日期等不同数据类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过typeof(value)方法可以判断当前变量的数据类型。

var a = {id:'1',name:'对象'};
var b = [1,2];
var c = new Date();

typeof(a);   //object
typeof(b);  //object
typeof(c);  //object
对象、数组和日期的结果都为object,不能将typeof作为判断其类型的依据。

每个变量都带有构造属性,用constructor函数可以获得。

a、b、c三个变量的构造函数分别为:

①a.constructor;  //Object() {...}

②b.constructor;  //Array() {...}

③c.contsructor; //Date()  {...}

实例:

function diffObject(value,type){ 
  return value.constructor.toString().indexOf(type) != -1;
}
console.log(diffObject(a,'Object')); //true
console.log(diffObject(a,'Array'));  //false
console.log(diffObject(b,'Array')); //true
console.log(diffObject(c,'Date')); //true
扩展知识:

javascript包含5种不同的数据类型。

  • 数字number
  • 字符串string
  • 布尔boolean
  • 对象object
  • 函数function

其中对象类型还分:

  • Object
  • Array
  • Date





### C# 中 `object` 类型数组的用法 在 C# 中,`object` 是所有类型的基类。因此,可以创建一个 `object[]` 数组来存储不同类型对象。这提供了灵活性但也带来了类型安全性的挑战。 #### 创建初始化 Object 数组 可以直接声明并初始化 `object` 类型数组: ```csharp // 声明并初始化 object 数组 object[] myObjects = new object[] { "字符串", // string 42, // int true, // bool DateTime.Now // DateTime }; ``` 此方法允许在同一数组中混合不同类型的数据[^1]。 #### 访问 Array Elements 访问 `object` 数组中的元素与其他任何数组相同的方式进行索引操作: ```csharp Console.WriteLine(myObjects[0]); // 输出: 字符串 Console.WriteLine(myObjects[1]); // 输出: 42 Console.WriteLine(myObjects[2]); // 输出: True 或 False 取决于实际值 Console.WriteLine(myObjects[3]); // 当前日期时间 ``` 需要注意的是,在从 `object` 转换回具体类型时可能会遇到性能开销以及潜在的风险——如果尝试转换为不兼容的类型,则会抛出异常。为了防止这种情况发生,应该先检查目标变量的实际运行时类型再做显式的强制转型处理。 #### 使用 foreach 遍历 Object 数组 也可以通过 `foreach` 循环遍历整个集合而无需关心下标位置: ```csharp foreach (var item in myObjects) { Console.WriteLine(item); } ``` 这段代码将依次打印每一个项的内容到控制台窗口上显示出来。 #### 将 Object 数组转为特定类型列表 当需要把一组异构的对象转化为某种特定类型的序列化结构(比如列表),可借助 LINQ 查询表达式完成过滤工作: ```csharp List<int> integersOnly = myObjects.OfType<int>().ToList(); ``` 上述语句仅保留那些能够被成功解析成整数形式的成员,并将其封装在一个新的泛型列表实例里返回给调用者使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值