总结Javascript基础

Posted 悠扬的牧笛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了总结Javascript基础相关的知识,希望对你有一定的参考价值。

javascript的数据类型

  •   Number
  •   String
  •   Boolean
  •   Undefined
  •   Null
  •   Object

如下图,其中NumberStringBooleanUndefinedNull是原始类型,Object是对象类型,Object中可以包含ArrayFunction等类型。

 

 

常规运算符

下面来看几行代码

1 var num=32
2 var str=”323 num+str=”3232” //利用这一点可以把数字转换为字符串
4 var num=123
5 num=num+””//”32”
num=”12”
num=num-0//转换成数字 12

当常规运算符左右两侧是NumberString的时候,如果是加号,会把Number转成String处理,如果是减号,则String会被转成Number处理,乘法和除法类似于减法。            

等于和严格等于

var c=(0==false) /true
var c=(0===false)// false 严格等于 除了类型相等,值也要相等
(null==undefined)//true
(null===undefined)//false

new Object() == new Object()// false  Object是引用类型
[1,2]==[1,2] //false 因为[1,2] 是Array 属于Object 所以是False

null==null  //true
null===null  //true

undefined==undefined//true
undefined===undefined//true

NaN==NaN //false
NaN===NaN //false NaN和谁都不想等,即使是自己

12=="12"//true  等号两边一个是数字一个是字符串,编译器会尝试把字符串转成数字

true==1//true 等号两边一个是布尔值一个是其他类型,编译器会尝试把布尔转成数字再比较
true=="1" //true
var a=new Object("123") 
a==123 //true
a=”123”//true
如果等号两边一边是Object另一边是Number或者String,Object会转换成基本类型再比较

类型包装

原始类型中,StringNumberBoolean都有包装类型

var str="string"
var s=new String("string") //String的包装类,包含了许多的方法和属性
str.t=10//str是基本类型,但是当我们把str附加一个属性并赋值的时候,Javascript会智能地把str转换为对应的临时的包装类型,当再次访问str的t属性的时候,发现值是undefined,因为生成的临时包装对象被销毁了,所以t的值变成了undefined。

类型检测

主要有5种类型检测方式

  • Typeof
  • instanceof 
  • Object.prototye.toString
  • Constructor
  • duck type
typeof 100 //"number"
typeof true//"boolean"
typeof function(){}//"function"
typeof(undefined)//"undefined"
typeof new Object()//"object"
typeof [1,2]//"object"
typeof NaN//"number"
typeof null//"object"?本来是规定返回“null” 但是这导致了大量的网站瘫痪,所以规定返回“Object”
typeof Null//"undefined"

null大小写不一致时返回的类型也不一样

typeof适用于原始类型以及function的检测,遇到null失效

instanceof 是基于原型链的,适用于Object自定义对象,也可以用来检测原生对象,在不同的iframe和window间检测时失效,右侧对象必须是函数对象或函数构造器,否则就会抛出异常

Object.Prototype.toString.appy([])通过{}.toString拿到,适合内置对象和原生类型,遇到nullundefined失效

instanceof 123 //会抛出如下异常
Uncaught SyntaxError: Unexpected token instanceof

[1,2] instanceof Array //true   !!!原理是判断左侧对象的原型链上是否有右侧构造函数的prototype属性。

ject.Prototype.toString.appy([]);===”[object Array]”
Object.Prototype.toString.appy(function(){});===”[object Function]”
Object.Prototype.toString.appy(nll);=== ”[object Null]” //IE 678 返回的是[objet object]兼容性问题
Object.Prototype.toString.appy(undefined);=== ”[object Undefined]”

 

 作者:悠扬的牧笛

 博客地址:http://www.cnblogs.com/xhb-bky-blog/p/5854646.html

 声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。

 

以上是关于总结Javascript基础的主要内容,如果未能解决你的问题,请参考以下文章

javascript --学习基础总结

JavaScript基础学习总结2 基础部分

VsCode 代码片段-提升研发效率

JavaScript基础总结三部曲之一

VSCode自定义代码片段12——JavaScript的Promise对象

VSCode自定义代码片段12——JavaScript的Promise对象