JavaScript OOP(一)之构造函数与new命令
面向对象编程:Object Oriented Programming,简称OOP。
使用构造函数和new示例:
var O1=function(){
this.name='apple';
};
/**
* 1.函数名一般大写进行区分;构造函数内部使用了this关键字
* 2.生成对象,使用new
*/
var o2=new O1();
console.log(typeof o2,o2);
function O2(){
this.name='microsoft';
}
var o3=new O2();
console.log(typeof o3,o2);
console.log('---');
运行结果:

构造函数也可以带参数:
var Apple=function(){
this.weight=100;
};
var a=new Apple();//相当于var a=new Apple;
console.log(a.weight);
var Apple1=function(weight){
this.weight=weight;
}
var a1=new Apple1(10);
console.log(a1.weight);
如果构造函数未带参数,那么使用new命令时,可以省略()。
运行结果:

如果没有使用new命令调用构造函数:那么this指向全局对象或者说是顶层对象(即window)
function Blue(){
this.money=1000;
}
var b1=new Blue();
var b2=Blue();//window.money
console.log(b1,b2);
console.log(b1.money,window.money,money);
运行结果:(b2:undefined)

为了避免出现不加new调用构造函数的情况:1.使用严格模式;2.构造函数内部对this的指向进行判断
//避免出现不加new情况,使用'use strict';
//在严格模式下,函数内部this不允许指向全局对象window,默认等于undefined
function Cat(){
'use strict';
this.color='white';
}
//var c1=Cat();//报错,不能将属性color添加给undefined function Dog(){
//如果this不指向当前对象Dog,那么使用new生成实例对象
if(!(this instanceof Dog)){
return new Dog();
}
this.name='xiaoming';
}
var d1=Dog();
console.log(d1);
var d2=new Dog();
console.log(d2);
运行结果:

构造函数中存在return语句:ruturn对象,那么new 返回return的这个对象;否则return无效,返回this
console.log('---');
function Ele(){
this.name='nicai';
return 100;
}
var e1=new Ele();
console.log(e1);
function Ele1(){
this.name='apple';
return {
name:'blue',
calss:'super calss'
};
}
var e2=new Ele1();
console.log(e2);
console.log(e2.name);//blue
运行结果:

普通函数使用new调用:生成空对象
//注意与普通函数进行区分;普通函数:内部没有this关键字、函数名一般以小写开头
function fire(){
var s='this is a test function';
return s;
}
var f1=new fire();
console.log(f1,typeof f1);
运行结果:

new.target属性:
//函数内部使用new.target属性。如果函数被new调用,则new.target等于当前函数;否则,new.target等于undefined
function Gird(){
this.name='gird';
console.log(new.target===Gird);
}
var g1=new Gird();//true
var g2=Gird();//false
运行结果:

参考:阮一峰标准参考教程
JavaScript OOP(一)之构造函数与new命令的更多相关文章
- Javascript中构造函数与new命令
典型的面向对象编程语言(比如C++和Java),存在“类”(class)这个概念.所谓“类”就是对象的模板,对象就是“类”的实例.但是,在JavaScript语言的对象体系,不是基于“类”的,而是基于 ...
- Javascript中构造函数与new命令2
典型的面向对象编程语言(比如C++和Java),存在"类"(class)这个概念.所谓"类"就是对象的模板,对象就是"类"的实例.但是,在J ...
- 玩转JavaScript OOP[2]——类的实现
概述 当我们在谈论面向对象编程时,我们在谈论什么?我们首先谈论的是一些概念:对象.类.封装.继承.多态.对象和类是面向对象的基础,封装.继承和多态是面向对象编程的三大特性. JavaScript提供了 ...
- JavaScript OOP 之 this指向
今天给大家分享一个JavaScript OOP中关于分辨this指向对象的小技巧,很实用呦! 我们先来看一段代码: 大家能判断出func();和obj.func();这两句的this指向吗? 首先,我 ...
- 使用JavaScript OOP特性搭建Web应用
最近,我面试了一个有五年 Web 应用程序开发经验的软件开发人员.四年半来她一直在从事 JavaScript 相关的工作,她自认为 JavaScript 技能非常好,但在不久之后我就发现实际上她对 J ...
- 玩转JavaScript OOP[3]——彻底理解继承和原型链
概述 上一篇我们介绍了通过构造函数和原型可以实现JavaScript中的“类”,由于构造函数和函数的原型都是对象,所以JavaScript的“类”本质上也是对象.这一篇我们将介绍JavaScript中 ...
- javascript继承之借用构造函数与原型
javascript继承之借用构造函数与原型 在js中,关于继承只有利用构造函数和原型链两种来现实.以前所见到的种种方法与模式,只不过是变种罢了. 借用构造函数 1 2 3 4 5 6 7 8 9 1 ...
- (二)Javascript面向对象编程:构造函数的继承
Javascript面向对象编程:构造函数的继承 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继承 ...
- javascript创建对象的方法--构造函数模式
javascript创建对象的方法--构造函数模式 一.总结 构造函数模式作用和不足 1.作用:解决工厂模式不是用new关键字来创建对象的弊端 2.作用:解决工厂模式创建的实例和模型没有内在联系的问题 ...
随机推荐
- MySQL数据库主从复制实践
MySQL 主从(MySQL Replication),主要用于 MySQL 的实时备份.高可用HA.读写分离.在配置主从复制之前需要先准备 2 台 MySQL 服务器. 一.MySQL主从原 ...
- 双端链表--Java实现
/*双端链表--比普通链表多了一个指向最后一个节点的引用 * 特点: 链表可以进行尾巴插入--输出顺序和输入顺序一致 * 但是不可以进行尾巴删除因为没有倒数第二节点的引用 * */ public cl ...
- 使用原生php读写excel文件
最近在工作中遇到一个需求,需要将数据库中的数据导出到excel文件中,并下载excel文件.因为以前没做过,所以就百度了一下, 网上说的大多是使用PHPExcel类来操作excel文件,这还要去下载这 ...
- jquery中常用的方法和注意点
1.通过js获取url中的参数值 //通过参数名称name获取url参数function GetQueryString(name) { var reg = new RegExp("(^|&a ...
- Best MVC Practices(最优的MVC布局)
Best MVC Practices 最优的MVC布局策略 Model View Controller 1.数据层 2.视图层 3.控制器层 Although Model-View-Controlle ...
- Cable master
Problem Description Inhabitants of the Wonderland have decided to hold a regional programming contes ...
- 0_Simple__clock + 0_Simple__clock_nvrtc
使用 clock() 函数在CUDA核函数内部进行计时,将核函数封装为PTX并在另外的代码中读取和使用. ▶ 源代码:文件内建核函数计时. #include <stdio.h> #incl ...
- robotframework2.8.7日志输出List乱码
今天在完善robotframework的数据分离的时候,需要读取list中的中文信息,在日志输出中,英文显示是正常的:但是中文就出现所谓的乱码情况,如截图所示 对于list中的信息,日志显示乱码:查找 ...
- 串口接收模块(verilog) 波特率115200
我来分享一下uart协议之接收verilog代码 顶层实例化 `timecale 1ns / 1ps////////////////////////////////////////////////// ...
- 面向亿万级用户的QQ一般做什么?——兴趣部落的Web同构直出分享
作者:李强,腾讯web开发工程师 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. 原文链接:http://wetest.qq.com/lab/view/348.html 一.什么是同构 ...