原型
来源:互联网 发布:纳粹军服淘宝有卖的吗 编辑:程序博客网 时间:2024/04/27 16:23
原型构造对象
原型构造对象的方式是从一个具体到具体的过程,即是会利用一个现有的对象为原型去构建另一个对象。
原型对象—->对象
JS里面有两种从原型对象中构建对象的方法
第一种:Object.create(proto[,propertiesObject])----proto一个对象,作为新创建对象的原型。这个函数会返回构建的对象------propertiesObject对象的属性定义Object.create实例://定义原型对象var landRover = { name:'landRover', start: function(){ console.log('%s start',this.logo); }, run: function(){ console.log('%s running', this.logo); }, stop: function(){ console.log('%s stop', this.logo); }}//使用原型创建新的对象var landWind = Object.creat(landRover); landWind.logo = 'landWind';var landCruiser = Object.create(landRover);landCruiser.logo = 'landCruiser';
第二种方法:构造函数/*function landRover(logo){ start: function(){ console.log('%s start',this.logo); }, run: function(){ console.log('%s running',this.logo); }, stop: function(){ console.log('%s stop', this.logo); }}var landWind = new landRover();*///设置对象的原型---实例function Car(logo){ this.logo = logo || 'unknown name';}Car.prototype = { start: function() { console.log('%s start', this.logo); }, stop: function(){ console.log('%s stop', this.logo); }, run: function(){ console.log('%s running', this.logo); }}var landRover = new Car('landRover');//执行这句时,其实是有三个步骤var landWind = new Car('landWind');//调用方法landRover.start();
上面的图表面了调用构造函数新建对象时的执行步骤,第三步是函数调用方法中的apply()调用,把对象传给了构造函数的this。
原型链–实例
JS中对象的属性和方法的访问删除和原型链有关
访问属性时,先从本身查询,依次向上。
修改和删除属性只能操作自身的属性
hasOwnProperty()
这个方法每个对象都有,来自于Object原型
判断一个属性是否属于对象自身
landRover.hasOwnProperty('serialno');//true//这是在判断属性serialno是否是landRover对象自身的,是为true,否定为false;
0 0
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型
- 原型与原型链
- 原型 和 原型链
- Nginx + IIS 实现负载均衡
- iOS开发——多线程
- 火红的夕阳刚刚落山
- BLE工作模式: Central+Peripheral(Advertising+Connected)
- 虚拟机centos7,开启samba,设置开机启动
- 原型
- Effective C++——条款54,条款55(第9章)
- git强制更新
- 当Android系统内存不足时,会回收后台运行应用的内存
- 家家户户低矮的房子
- 安卓Apk获取设备信息
- HttpClient使用时遇到几个隐蔽小坑分析
- 让一个程序在后台运行并把输入定向到指定的文件
- iOS 系统自带定位