龙空技术网

「案例学习」JS的构造函数

java笔记 87

前言:

当前兄弟们对“js数据结构算法”大约比较看重,小伙伴们都想要了解一些“js数据结构算法”的相关资讯。那么小编也在网络上网罗了一些对于“js数据结构算法””的相关资讯,希望朋友们能喜欢,看官们快快来了解一下吧!

构造函数

所谓”构造函数”,就是专门用来生成实例对象的函数。它就是对象的模板,描述实例对象的基本结构。一个构造函数,可以生成多个实例对象,这些实例对象都有相同的结构。

构造函数内部的 this

案例1:函数内部不使用 this

var f1 = function(){	a = 1;}var o1 = new f1();console.log(o1.a);  // undefined

1.测试

案例2: 函数内部使用 this

var f2 = function(){	this.a=1;}var o2 = new f2()console.log(o2.a);  // 1

2.测试

new 构造函数

案例3:使用 new

var o1 = new f1();console.log( o1 );

3.测试

案例4:不使用 new

var o2 =  f1();console.log( o2 ); // undefined

4.测试

函数内部的 return

案例5:没有 return 语句 , new 构造函数返回: this。

var that ;var f3 = function(){ 	 that = this;}console.log('new f3())===that:',(new f3())===that); // true

5.验证

案例6: return 一个对象,new 构造函数返回:该对象。

var obj ;var f3 = function(){ 	 obj = {a:3}  return obj;}console.log('(new f3())===obj:',(new f3())===obj); // true

6.验证

案例7:return 一个值,new 构造函数返回: this。

var value ;var that;var f3 = function(){  that = this; 	value = 1;  return value;}console.log('(new f3())===value:',(new f3())===value); // falseconsole.log('(new f3())===that:',(new f3())===that); // true 实际返回 this

7.验证

保证构造函数必须与 new 命令一起使用

案例8:使用 'use strict'

function f4(){  'use strict';  this.a = 2;}f4() // 没有使用new: 报错 //原因:由于严格模式中,函数内部的this不能指向全局对象,默认等于undefined,导致不加new调用会报错(JavaScript 不允许对undefined添加属性)

8.验证

案例9:在构造函数内部判断

function f5(){  if( !( this instanceof  f5 ) ){    return new f5();  } this.a =1; }console.log( new f5().a ); // 使用new: 1console.log( f5().a ); //  没有使用new: 1  

9.验证

案例10:new.target

function f6() {  if (!new.target) { // 如果当前函数是new命令调用,new.target指向当前函数,否则为undefined。    throw new Error('请使用 new 命令调用!');  }  // ...}f6() // 没有使用new: 报错

10.验证

通过现有的对象创建一个新对象

案例11:

var obj1 = { a:1 }var obj2 = Object.create(obj1)console.log('obj1===obj2',obj1===obj2) //false

11.验证

注:本案例根据阮一峰 js 教程学习总结,推荐前往阅读!

参考:

标签: #js数据结构算法 #js结构 #js构造函数模式 #js调用内部函数 #js重构函数