我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript构造函数怎么自定义

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript构造函数怎么自定义

这篇文章主要介绍“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构造函数怎么自定义”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript构造函数怎么自定义

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

下载Word文档

猜你喜欢

JavaScript构造函数怎么自定义

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

Android自定义View构造函数详解

初始Custom View的构造函数 之前写过一篇实现圆形进度条的博客(自定义圆形进度条),通常我们在实现Custom View的时候,都会先继承View并实现View的三个构造函数,例如:import android.content.Co
2022-06-06

C++中怎么定义一个构造函数

C++中怎么定义一个构造函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。C++构造函数初始化列表以一个冒号开始,接着是以逗号分隔的数据成员列表,每个数据成员后
2023-06-17

Android 自定义View的构造函数详细介绍

Android自定义View的构造函数自定义View是Android中一个常见的需求,每个自定义的View都需要实现三个基本的构造函数,而这三个构造函数又有两种常见的写法。 第一种 每个构造函数分别调用基类的构造函数,再调用一个公共的初始
2022-06-06

怎么在Android中利用构造函数对View进行自定义

本篇文章给大家分享的是有关怎么在Android中利用构造函数对View进行自定义,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。自定义View有三个构造方法,它们的作用是不同的。
2023-05-31

JavaScript怎么自定义函数求累加

这篇文章主要介绍了JavaScript怎么自定义函数求累加的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript怎么自定义函数求累加文章都会有所收获,下面我们一起来看看吧。什么是累加?累加即将数字序
2023-07-06

C++类、对象、构造函数及析构函数怎么定义使用

这篇文章主要介绍“C++类、对象、构造函数及析构函数怎么定义使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++类、对象、构造函数及析构函数怎么定义使用”文章能帮助大家解决问题。C++类与对象C
2023-07-06

javascript构造函数怎么借用

本篇内容主要讲解“javascript构造函数怎么借用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript构造函数怎么借用”吧!说明1、调用子类构造函数中的父类构造函数。采用app
2023-06-20

JavaScript如何自定义函数

这篇文章主要介绍“JavaScript如何自定义函数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript如何自定义函数”文章能帮助大家解决问题。JavaScript中的函数分为两种:系
2023-06-29

javascript new怎么调用构造函数

本篇内容主要讲解“javascript new怎么调用构造函数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript new怎么调用构造函数”吧!说明1、在内存中创建新对象。2、新对
2023-06-20

JavaScript自定义函数求累加

JavaScript是一种用于编写Web应用程序的高级编程语言,其强大的能力和广泛的用途已经使它成为Web开发中必备的工具之一。 在JavaScript中,自定义函数是一种非常重要的技术,它允许我们根据自己的需求编写并调用函数。在本文中,我们将介绍如何使用JavaScript自定义函数求累加。什么是累加?累加即将数字序列中的所有数字相加。例如,如果我们有数字序列1, 2, 3,
2023-05-14

java怎么定义构造方法

在Java中,构造方法是一种特殊的方法,用于创建和初始化对象。构造方法的定义和普通方法有所不同,它的名称必须与类名完全相同,且没有返回类型(包括void),因为构造方法的返回值是创建的对象。以下是Java中定义构造方法的基本语法:```ja
2023-09-01

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录