在chrome的控制台中查看对象的结构树
console.dir(document); //比如查看document对象的结构树
1.在js中几乎一切都是对象,可以和对象一样直接调用其方法,只有null和undefined除外,比如
false.toString(); //"false"
null.toString(); //TypeError: Cannot read property 'toString' of null
undefined.toString(); //TypeError: Cannot read property 'toString' of undefined
2.__proto__是对象的内置属性,是js查找原型链时需要的属性;prototype是js中函数拥有的属性。
当访问对象的属性或者方法时,先在对象内部进行查找,如果在当前对象内部没有找到,就会沿着__proto__所指的对象继续向上查找,直至查找到Object对象。
3.对象由对象字面量构造时:
var dog={clawCount:4};
console.dir(dog.__proto__ === Object.prototype); //true
对象由构造函数构造时:
var Dog = function () { };
var dog = new Dog();
console.log(dog.__proto__ === Dog.prototype); //true
//可以在原型链上层的对象上添加属性或方法,添加后对象即可直接访问
//要判断属性是否属于对象本身而非从原型链继承过来可以使用hasOwnProperty()方法判断
Dog.prototype.clawCount = 4;
Dog.prototype.bark = function () {
alert('wang wang');
};
console.log(dog.clawCount);
dog.bark();
对象由Object.create()方法构造(浏览器兼容不一):
var dog1 = {};
var dog2 = Object.create(dog1);
console.log(dog2.__proto__ === dog1); //true
4.在js中可以直接为对象添加属性和方法,也可以利用delete删除相应的属性,成功则返回true;
如果是全局作用域的变量和函数,则无法删除。