位置: 编程技术 - 正文

在JavaScript中typeof的用途介绍(在javascript中逻辑运算符包括)

编辑:rootadmin

JavaScript 中的 typeof 其实非常复杂,它可以用来做很多事情,但同时也有很多怪异的表现。

本文列举出了它的多个用法,而且还指出了存在的问题以及解决办法。

阅读本文的前提是,你现在应该已经知道原始值和对象值的区别了。

检查一个变量是否存在,是否有值typeof在两种情况下会返回 "undefined":

1.变量没有被声明

2.变量的值是 undefined

例如:

还有其他办法检测某个值是否是 undefined:

但这种方法如果使用在一个未声明的变量上的时候,就会抛出异常,因为只有 typeof 才可以正常检测未声明的变量的同时还不报错:

注意:未初始化的变量,没有被传入参数的形参,不存在的属性,都不会出现上面的问题,因为它们总是可访问的,值总是 undefined:

译者注:因此,如果想检测一个可能没有被声明的全局变量是否存在,也可以使用if(window.maybeUndeclaredVariable){}。

问题:typeof 在完成这样的任务时显得很繁杂.

解决办法:这样的操作不是很常见,所以有人觉的没必要再找更好的解决办法了。 不过也许有人会提出一个专门的操作符:

或者,也许有人还需要一个检测变量是否被声明的操作符:

译者注:在 perl 里,上面的 defined 操作符相当于 defined(),上面的 declared 操作符相当于 exists()。

判断一个值不等于 undefined 也不等于 null问题:如果你想检测一个值是否被定义过(值不是 undefined 也不是 null),那么你就遇到了 typeof 最有名的一个怪异表现(被认为是一个 bug):typeof null 返回了 "object":

译者注:这只能说是最初的 JavaScript 实现的 bug,而现在标准就是这样规范的。V8 曾经修正并实现过 typeof null === "null",但最终证明不可行。 在操作 null 时会返回 "object",这是 JavaScript 语言本身的 bug。不幸的是,这个 bug 永远不可能被修复了,因为太多已有的代码已经依赖了这样的表现。但是 null 到底是不是 对象呢?stackoverflow 有关于这个问题的讨论: typeof 来做这项任务,用下面这样的函数来代替:

另一个可能性是引入一个 “默认值运算符”,在 myValue 未定义的情况下,下面的表达式会返回 defaultValue:

上面的表达式等价于:

又或者:

其实是下面这条语句的简化:

当你访问一个嵌套的属性时,比如 bar,你或许会需要这个运算符的帮助:

如果 obj 或者 obj.foo 是未定义的,上面的表达式会抛出异常。 一个运算符 .?? 可以让上面的表达式在遍历一层一层的属性时,返回第一个遇到的值为 undefined 或 null 的属性:

上面的表达式等价于:

区分对象值和原始值

下面的函数用来检测 x 是否是一个对象值:

问题:上面的检测比较复杂,是因为 typeof 把函数和对象看成是不同的类型,而且 typeof null 返回 "object".

解决办法:下面的方法也经常用于检测对象值:

警告:你也许认为这里可以使用 instanceof Object 来检测,但是 instanceof 是通过使用使用一个对象的原型来判断实例关系的,那么没有原型的对象怎么办呢:

obj 确实是一个对象,但它不是任何值的实例:

在实际中,你可能很少遇到这样的对象,但它的确存在,而且有它的用途。

译者注:Object.prototype 就是唯一的一个内置的,没有原型的对象。

原始值的类型是什么?typeof 是最好的用来查看某个原始值的类型的方式。

问题:你必须知道 typeof null 的怪异表现。

解决办法:下面的函数可以修复这个问题(只针对这个用例)。

更好的解决办法:实现一个函数 getTypeName(),除了可以返回原始值的的类型,还可以返回对象值的内部 [[Class]] 属性。 这里讲了如何实现这个函数(译者注:jQuery 中的 $.type 就是这样的实现)

某个值是否是函数typeof 可以用来检测一个值是否是函数。

原则上说,instanceof Function 也可以进行这种需求的检测。 乍一看,貌似写法还更加优雅。 但是,浏览器有一个怪癖:每一个框架和窗口都有它自己的全局变量。 因此,如果你将某个框架中的对象传到另一个框架中,instanceof 就不能正常工作了,因为这两个框架有着不同的构造函数。 这就是为什么 ECMAScript5 中会有Array.isArray() 方法的原因。 如果有一个能够跨框架的,用于检查一个对象是否是给定的构造函数的实例的方法的话,那会很好。 上述的 getTypeName() 是一个可用的变通方法,但也许还有一个更根本的解决方案。

综述下面提到的,应该是目前 JavaScript 中最迫切需要的,可以代替一些 typeof 目前职责的功能特性:

&#;isDefined() (比如 Object.isDefined()): 可以作为一个函数或者一个运算符

&#;isObject()

&#;getTypeName()

&#;能够跨框架的,检测一个对象是否是指定的构造函数的实例的机制

检查某个变量是否已经被声明这样的需求,可能没那么必要有自己的运算符。

推荐整理分享在JavaScript中typeof的用途介绍(在javascript中逻辑运算符包括),希望有所帮助,仅作参考,欢迎阅读内容。

在JavaScript中typeof的用途介绍(在javascript中逻辑运算符包括)

文章相关热门搜索词:在javascript中typeo运算符的目的,在javascript中逻辑运算符包括,在javascript中typeo运算符的目的,在Javascript中,()方法可以对数组元素进行排序,在Javascript中,()方法可以对数组元素进行排序,在javascript中如果不指明对象直接调用,在javascript中如果不指明对象直接调用,在javascript中typeo运算符的目的,内容如对您有帮助,希望把文章链接给更多的朋友!

在JavaScript并非所有的一切都是对象 虽然很多语言宣称:一切皆是对象,但是javascript中,并不是所有的值都是对象。原始值vs对象javascript中的值可以被划分为两大类:原始值(primitive)和

谈谈关于JavaScript 中的 MVC 模式 原文:Model-View-Controller(MVC)withJavaScript作者:Alex@Net译文:JavaScript的MVC模式译者:justjavac本文介绍了模型-视图-控制器模式在JavaScript中的实现。我喜欢Java

你的 mixin 真的兼容 ECMAScript 5 吗? 我最近在与客户合作的项目中,需要充分利用的ECMAScript5,在此我遇到一个非常有趣的问题。该问题源于一个非常常见的模式:mixin,也就是在JavaScript

标签: 在javascript中逻辑运算符包括

本文链接地址:https://www.jiuchutong.com/biancheng/377654.html 转载请保留说明!

上一篇:裁剪字符串trim()自定义改进版(string剪切)

下一篇:在JavaScript并非所有的一切都是对象(&&在js中)

  • 合同履约成本资本化
  • 研发机构采购设计方案
  • 房地产增值税税率是多少
  • 微信收款和支付宝收款有啥区别
  • 酒店购买的空调折旧计入管理费用吗
  • 以前年度损益调整结转到哪里
  • 分公司与总公司的法律关系
  • 往期附加税申报错误更正后怎么退税
  • 抽奖中的汽车需要交购置税吗
  • 可抵扣的固定资产
  • 工程成本控制方法
  • 未开票收入已报税怎么办
  • 公司广告法违规交不起罚款怎么办
  • 跨年发票冲红重新开具购买方做账不
  • 金税盘?
  • 小规模纳税人未达起征点增值税处理
  • 土地闲置费能否扣除
  • 补提以前年度税费应该计入
  • 多交企业所得税怎么申请抵缴
  • 政府发放的稳岗补贴怎么做账
  • 个税退手续费要多久到账
  • win10 21h1正式版怎么样
  • 汽车过户费包括
  • 没有一般纳税人证明怎么办
  • 数字证书费用计入管理费用什么科目
  • 盒装cpu和散装
  • 【Fiddler Everywhere】史上最强抓包工具(安装 修改教程)
  • 利息年化率怎么算化利率怎么算
  • 处置动产减按2%税率是什么意思
  • 企业延期收款
  • php如何生成html
  • 营改增工程计价规则
  • framework怎么查看
  • 未注销的坏账可以处理吗
  • yii框架搜索分页modle写法
  • 创建数据的命令是
  • phpcms怎么用
  • 财务费用的利息费用怎么算
  • 研发支出放在资产负债表哪里
  • 农产品收购发票是普票还是专票
  • 一般纳税人进项税怎么抵扣
  • 食堂增值服务有哪些
  • mongodb 随机获取一条数据
  • 小规模纳税人销售商品会计分录
  • 公司活动赠送小礼品
  • 高新企业申请流程
  • 工资结算汇总表怎么填
  • 2023小型微利企业税收优惠
  • datatable怎么用
  • 银行开的手续费发票开错了
  • 安全生产费如何计量
  • 行政机关现金管理办法
  • 预存返现活动规则
  • 会计科目用错如何改正
  • 网络竞价须知
  • 电子承兑被拒付(可拒付追索)
  • 发票备注栏填写内容
  • 属于费用类的会计科目有哪些
  • 工业企业低值易耗品二级科目
  • sqlserver查询数据库数据量
  • centos下载软件并安装
  • win10电脑无法上网
  • win8怎么删除输入法
  • windows视频截屏
  • 文件夹windows
  • win8怎么打开远程连接
  • jquery开发
  • jquery 设置背景色
  • 单页图片和文字怎么设置
  • 批处理延迟变量
  • jQuery使用animate实现ul列表项相互飘动效果示例
  • jquery版本区别
  • jquery中动画效果方法
  • js字段截取
  • jquery怎么实现分页功能
  • 广东省电子税务局app下载手机版
  • 增值税税控开票软件密码不知道了怎么办
  • 个人所得税自行纳税申报表(A表)
  • 新吉高铁开工典礼
  • 哪个部门负责药品检验
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设