总结Javascript基础
Posted 悠扬的牧笛
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了总结Javascript基础相关的知识,希望对你有一定的参考价值。
javascript的数据类型
- Number
- String
- Boolean
- Undefined
- Null
- Object
如下图,其中Number
、String
、Boolean
、Undefined
、Null
是原始类型,Object
是对象类型,Object
中可以包含Array
、Function
等类型。
常规运算符
下面来看几行代码
1 var num=32 2 var str=”32” 3 num+str=”3232” //利用这一点可以把数字转换为字符串 4 var num=123 5 num=num+””//”32”
num=”12” num=num-0//转换成数字 12
当常规运算符左右两侧是Number
和String
的时候,如果是加号,会把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会转换成基本类型再比较
类型包装
原始类型中,String
、Number
、Boolean
都有包装类型
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拿到,适合内置对象和原生类型,遇到null
和undefined
失效
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基础的主要内容,如果未能解决你的问题,请参考以下文章