广告
返回顶部
首页 > 资讯 > 精选 >JavaScript构造函数怎么自定义
  • 103
分享到

JavaScript构造函数怎么自定义

2023-07-05 22:07:54 103人浏览 八月长安
摘要

这篇文章主要介绍“javascript构造函数怎么自定义”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript构造函数怎么自定义”文章能帮助大家解决问题。典型的面向对象编程语言(比如c+

这篇文章主要介绍“javascript构造函数怎么自定义”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript构造函数怎么自定义”文章能帮助大家解决问题。

典型的面向对象编程语言(比如c++和Java),存在“类”(class)这个概念。所谓“类”就是对象的模板,对象就是“类”的实例。但是,在JavaScript语言的对象体系,不是基于“类”的,而是基于构造函数(constructor)和原型链(prototype)

‘面向对象编程’的第一步,就是要生成对象。而js中面向对象编程是基于构造函数(constructor)和原型链(prototype)的。

前面说过,“对象”是单个实物的抽象。通常需要一个模板,表示某一类实物的共同特征,然后“对象”根据这个模板生成。
js语言中使用构造函数(constructor)作为对象的模板,所谓构造函数,就是提供一个生成对象的模板,并描述对象的基本结构的函数。一个构造函数,可以生成多个对象,每个对象都有相同的结构。

对于JS中的任何一个普通函数,当用new关键字来调用时,它就是构造函数。可见与函数定义无关,与调用方法有关。在社区中,通常默契地将函数名首字母大写来表示该函数以后希望被作为构造函数来使用

作用:构造新对象,设置对象的属性和方法

ECMAScript提供了多个内置构造函数,如 Object、Array、String、Boolean、Number、Date…等等。

var obj = new Object();var arr = new Array();

ECMAScript也允许自定义构造函数

构造函数一般首字母会大写,为了和普通函数区分

一个构造函数可以通过new创建多个实例对象

创建构造函数时,里面的属性和方法前必须加this,this就表示当前运行时的对象

    function Person(name, height) {          this.name = name;          this.height = height;          this.bark = function(fs){          return fs               }     }        var boy = new Person('Keith', 180);      console.log(boy);  //Person {name: 'Keith', height: 180, bark: ƒ}      console.log(boy.constructor);  //f Person(){}  //整个构造函数原型      console.log(boy.bark(8));  //8      console.log(boy.name); //'Keith'      console.log(boy.height); //180
 function Cat1(name){            this.name = name; console.log(this)  //先打印 new的时候打印  Cat1 {name: 'kk'}       } var cat3 = new Cat1("kk"); console.log(cat3);   //后打印  Cat1 {name: 'kk'} 指向原型链,再赋值

构造函数的return

  function Dog(){      this.name = "贝贝";      this.bark = function(){          console.log("汪汪汪");      }      // return 0;      // return [];  }  var d1 = new Dog();  console.log(d1);//Dog {name: '贝贝', bark: ƒ}  //构造函数不需要return 就可以返回结果

return一个基本数据类型,结果不变,依旧返回一个对象

例:

return 0;console.log(d1);//Dog {name: '贝贝', bark: ƒ}

return一个复杂数据类型,返回一个复杂数据类型

例:

return [];console.log(d1);//[]

构造函数构造出的对象带有类型标识

console.log(p1)  Person {  name: 'zs',  age: 12,  eating: [Function: eating],}  //打印结果有类型标识  //Person 就是类型标识console.log(p1){name: 'zs', age: 12, eating:[Function: eating]} //无类型标识的

构造函数的原理(new之后发生了什么)

构造函数之所以能构造出对象,其实JS帮助我们做了很多骚操作。你以为new之后直接执行函数体代码,其实并不是,事实比我们看到了多了四步

JavaScript构造函数怎么自定义

1 自从用new调用函数后,JS引擎就会在内存中创建一个空对象{}

const newObj = {};

2 新对象的__proto__属性指向构造函数的原型对象

(通俗理解就是新对象隐式原型__proto__链接到构造函数显式原型prototype上。)

newObj.__proto__ = functionName.prototype

3 构造函数内部的this会指向这个新对象(即将构造函数的作用域指向新对象)

this = newObj

4 从上到下执行函数体(只有这步是我们能直观看到代码的)

5 返回创造出来的对象(如果构造函数没有返回对象,则默认返回this。在函数体内部的this指向新创建的内存空间,默认返回 this 就相当于默认返回了该内存空间)

例子:

function Person(name, age) {this.name = name;this.age = age;this.eating = function() {console.log(this.name + ' is eating');}}const p1 = new Person('zs', 12);//----------------------------------------------------------------------------const newObj = {};newObj.__proto__ = Person.prototype;this = newObj;this.name = name;this.age = age;this.eating = function() {  console.log(this.name + ' is eating');}return newObj;

在构造函数原型上绑定方法节省空间

采用构造函数的确可以批量创建对象,且对象还都有该构造函数的loGo,那么构造函数有什么缺点吗?有的。由于每次函数调用都会创建新的对象,对象中的函数(比如eating)也会创建多份,对于函数而言创建多份没有必要,能不能共用一个函数呢?

function Person(name, age) {this.name = name;this.age = age;}const p1 = new Person('zs', 12);// 在函数原型上添加方法Person.prototype.eating = function() {console.log(this.name + ' is eating'); // zs is eating    return 5}console.log(p1.eating());  //5

将方法转移到构造函数原型上来定义后,对于实例对象p1,依然可以调用eating方法。调用p1的eating方法时,如果p1对象没有该方法,会去p1对象的原型对象p1.__proto_找,因为在构造p1时,绑定的原型:p1.__proto__ = Person.prototype,所以可以找到p1.__proto__.eating

关于“JavaScript构造函数怎么自定义”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: JavaScript构造函数怎么自定义

本文链接: https://www.lsjlt.com/news/355628.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript构造函数怎么自定义
    这篇文章主要介绍“JavaScript构造函数怎么自定义”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript构造函数怎么自定义”文章能帮助大家解决问题。典型的面向对象编程语言(比如C+...
    99+
    2023-07-05
  • Android自定义View构造函数详解
    初始Custom View的构造函数 之前写过一篇实现圆形进度条的博客(自定义圆形进度条),通常我们在实现Custom View的时候,都会先继承View并实现View的三个构...
    99+
    2022-06-06
    view 函数 Android
  • C++中怎么定义一个构造函数
    C++中怎么定义一个构造函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。C++构造函数初始化列表以一个冒号开始,接着是以逗号分隔的数据成员列表,每个数据成员后...
    99+
    2023-06-17
  • Android 自定义View的构造函数详细介绍
     Android自定义View的构造函数 自定义View是Android中一个常见的需求,每个自定义的View都需要实现三个基本的构造函数,而这三个构造函数又有两种...
    99+
    2022-06-06
    view 函数 自定义view 构造函数 Android
  • 怎么在Android中利用构造函数对View进行自定义
    本篇文章给大家分享的是有关怎么在Android中利用构造函数对View进行自定义,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。自定义View有三个构造方法,它们的作用是不同的。...
    99+
    2023-05-31
    android view roi
  • C++类、对象、构造函数及析构函数怎么定义使用
    这篇文章主要介绍“C++类、对象、构造函数及析构函数怎么定义使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++类、对象、构造函数及析构函数怎么定义使用”文章能帮助大家解决问题。C++类与对象C...
    99+
    2023-07-06
  • javascript构造函数怎么借用
    本篇内容主要讲解“javascript构造函数怎么借用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript构造函数怎么借用”吧!说明调用子类构造函数中的父类构造函数。采用apply...
    99+
    2023-06-20
  • JavaScript如何使用构造函数的方式定义新数组
    这篇文章主要为大家展示了“JavaScript如何使用构造函数的方式定义新数组”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何使用构造函数...
    99+
    2022-10-19
  • JavaScript怎么自定义函数求累加
    这篇文章主要介绍了JavaScript怎么自定义函数求累加的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript怎么自定义函数求累加文章都会有所收获,下面我们一起来看看吧。什么是累加累加即将数字序列...
    99+
    2023-07-06
  • javascript new怎么调用构造函数
    本篇内容主要讲解“javascript new怎么调用构造函数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript new怎么调用构造函数”吧!说明在内存中创建新对象。新对象内部的...
    99+
    2023-06-20
  • JavaScript函数怎么定义
    这篇文章主要介绍了JavaScript函数怎么定义的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript函数怎么定义文章都会有所收获,下面我们一起来看看吧。   ...
    99+
    2022-10-19
  • JavaScript如何自定义函数
    这篇文章主要介绍“JavaScript如何自定义函数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript如何自定义函数”文章能帮助大家解决问题。JavaScript中的函数分为两种:系...
    99+
    2023-06-29
  • java怎么定义构造方法
    在Java中,构造方法是一种特殊的方法,用于创建和初始化对象。构造方法的定义和普通方法有所不同,它的名称必须与类名完全相同,且没有返...
    99+
    2023-09-01
    java
  • javascript的自定义函数是什么
    这篇文章主要讲解了“javascript的自定义函数是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的自定义函数是什么”吧! ...
    99+
    2022-10-19
  • JavaScript中怎么定义函数
    这篇文章给大家介绍JavaScript中怎么定义函数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JavaScript函数函数为程序设计人员提供了一个丰常方便的能力。通常在进行一个复杂...
    99+
    2022-10-19
  • JavaScript中如何自定义函数
    JavaScript中如何自定义函数,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 js自定义函数的写法:1、“f...
    99+
    2022-10-19
  • JavaScript自定义函数求累加
    JavaScript是一种用于编写Web应用程序的高级编程语言,其强大的能力和广泛的用途已经使它成为Web开发中必备的工具之一。 在JavaScript中,自定义函数是一种非常重要的技术,它允许我们根据自己的需求编写并调用函数。在本文中,我...
    99+
    2023-05-14
  • shell中怎么自定义函数
    shell中怎么自定义函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、定义函数代码如下:function fname(){statements;}或代码如...
    99+
    2023-06-09
  • Vue怎么自定义hook函数
    这篇文章主要介绍“Vue怎么自定义hook函数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue怎么自定义hook函数”文章能帮助大家解决问题。定义什么是hook本质是一个函数,把 setup 函...
    99+
    2023-07-02
  • MySQL中怎么自定义函数
    MySQL中怎么自定义函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。控制流程函数  case...when  根据值判断返...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作