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.作用:解决工厂模式创建的实例和模型没有内在联系的问题 ...
随机推荐
- Java 获取SQL查询语句结果
step1:构造连接Class.forName("com.mysql.jdbc.Driver"); Connection con = DriverManager.getConnec ...
- PHP设计模式二:单例模式
一.什么是单例模式 作为对象的创建模式,单例模式确保某一个类只有一个实例,并且对外提供这个全局实例的访问入口.它不会 创建实例副本,而是会向单例类内部存储的实例返回一个引用. 二.PHP单例模式三要素 ...
- 使用prettytable美化python的print输出
经常碰到需要将一些数据用表格形式输出来.自己手动写太麻烦. 用prettytable能很好解决这个问题. ...(未完)
- 读书笔记-你不知道的JS上-this
关于this 与静态词法作用域不用,this的指向动态绑定,在函数执行期间才能确定.感觉有点像C++的多态? var a = 1; var obj = { a: 2, fn: function() { ...
- 使用SQL Server2014作业定时执行无参的存储过程
一.存储过程 1.新建存储过程 按照下图找到存储过程,右键“新建”选择”存储过程” 此时在右侧会打开一个窗口,如下图. 2.填写创建存储过程语句 填写存储过程名称,因为是无参的存储过程,所以把参数部分 ...
- rewrite写法
RewriteRule ^/android-special-(\d+).html$ /special/index.php?c=index&a=specialDetail&speid=$ ...
- css基础语法三
[]伪类选择器] 1.写法: 伪类选择器,在选择器后面,用:分隔,紧接伪类状态: eg : .a:link 2. 超链接的伪类状态: :link - 未访问状态 :visited - 已访问状态 :h ...
- 0_Simple__simpleAssert + 0_Simple__simpleAssert_nvrtc
在核函数中使用强制终止函数 assert().并且在静态代码和运行时编译两种条件下使用. ▶ 源代码:静态使用 #include <windows.h> #include <stdi ...
- C# linq左连接与分组
1.左连接使用DefaultIfEmpty(): 2.分组时候判断newper.FirstOrDefault() == null ? null: newper.ToList()这个经常出错误,如果不判 ...
- linq中怎么实现多条件关联的左右连接
linq左右连接最重要的是DefaultIfEmpty()这个方法和join之后的表中判断是否( temp != null)null,左右连接其实就是表的位置互换. 1.左连接: && ...