/*判断类型*/ function show(x){ /*undefined,number,string,boolean属于简单的值类型,值类型的判断用typeof*/ console.log(typeof x);//undefined console.log(typeof 10);//number console.log(typeof 'abc');//string console.log(typeof true);//boolean /*函数,数组,对象,null,new Number(10)都是对象,都是引用类型,引用类型的判断用instanceof*/ /*一切引用类型都是对象*/ console.log(typeof function(){});//function console.log(typeof [1,'a',true]);//object console.log(typeof {a:10,b:20});//object console.log(typeof null);//object console.log(typeof new Number(10));//object console.log(function(){} instanceof Object);//true console.log( [1,'a',true] instanceof Object);//true console.log({a:10,b:20} instanceof Object);//true console.log(null instanceof Object);//false console.log(new Number(10) instanceof Object);//true } /*对象都是通过函数创建的*/ var obj={a:10,b:2}; var obj=new Object();/*代码的本质*/ obj.a=10; obj.b=20; /*每个函数都有一个属性叫prototype,这个prototype的属性值是一个对象(属性的集合) * 默认的只有一个叫做constructor的属性指向这个函数本身*/ function name(){ console.log(555) } name.prototype.liuhao=function(){ console.log(555555) } console.log(name.prototype)/ console.log(name.prototype.constructor) /*Fn是一个函数,fn对象是从Fn函数new出来的,这样fn对象就可以调用Fn.prototype中的属性*/ function Fn(){} Fn.prototype.name="liuhao"; Fn.prototype.getYear=function(){ return 1998; } var fn=new Fn(); console.log(fn.name) console.log(fn.__proto__===Fn.prototype)//__proto__:隐式原型 /*每个函数function都有一个prototype,即原型。每个对象都有一个__proto__,隐式原型*/ /*每个对象都有一个__proto__属性,指向创建该对象的函数的prototype*/ /*Object.prototype确是一个特例--它的__proto__指向的是null*/ /*函数是谁创建出来的--是Function*/ function fn2(x,y){ return x+y; } console.log(fn2(1,2)); var fn1=new Function("x",'y',"return x+y");
/*instanceof A instanceof B
* instanceof 的判断规则是:沿着A的__proto__这条线来找,同时沿着B的prototype
* 这条线来找,如果这两条线能找到同一个引用,即同一个对象,那么就返回true
* 如果找到终点还未重合,则返回false
* instanceof 表示的就是一种继承关系,或者原型链的结构
* 访问一个对象的属性时,先在基本属性中查找,如果没有,再沿着__proto__这条链
* 向上找,这就是原型链
* */