javascript基础知识学习笔记——五种方法判断变量类型,大厂直通车

本文介绍了JavaScript中几种常见的类型判断方法,如使用`typeof`操作符、`instanceof`和`constructor`,以及利用`Array.isArray`API和`toString`方法来区分数组和对象。作者强调了实践的重要性,指出通过掌握这些内容,开发者可达到中级开发工程师水平。
摘要由CSDN通过智能技术生成

var str=“1”

console.log(typeof str); //“string”

var obj={};

console.log(typeof obj); //object

var fun=function(){};

console.log(typeof fun); //function

var arr=[];

console.log(typeof arr); //object

console.log(typeof Math); //object

console.log(typeof new RegExp()); // object

二、instandof

=========================================================================

对于引用类型或者有构造器的函数对象,可以用这个instandof区分变量是否是该对象的子类或者派生出来的。缺点无法区别五大基本类型。

//是否为数组

function judgeArray(arr){

if(typeof arr ==“object”){

console.log(arr instanceof Array)

return true

}

return false

}

var arr=[];

judgeArray(arr); //true

var obj={};

judgeArray(arr); //false

三、构造器

===================================================================

创建一个对象时js会在该对象的原型链prototype属性上添加构造器,该构造器同时又指向了自身,即new Array().constructor==Array,为true。缺点无法区别五大基本类型。

console.log([].constructor==Array) ;//true

console.log(new Object().constructor==Object) ;//true

四、api

===================================================================

es5为数组提供了一个isArray的函数用来区分数组的,具体可以看上一篇文章,关于数组api的总结。缺点是受具体的api的限制,有很多变量类型都没有现成的api

var arr=[];

var obj={};

console.log(Array.isArray(arr)); //true

console.log(Array.isArray(obj)); //false

五、tostring

========================================================================

toString()方法是顶级父类Object对象的原生属性,补充一点Object的原型指向Null,而该方法返回对象类型。缺点是无法判断undefined类型。

var n=null;

console.log(Object.prototype.toString.call(null)); //[object Null]

var bool=true;

console.log(Object.prototype.toString.call(bool)); //[object Boolean]

var num=1

console.log(Object.prototype.toString.call(num)); //[object Number]

var str=“1”
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

  • 15
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值