JavaScript自定义构造函数

在JavaScript中,我们可以使用构造函数来创建自定义对象。构造函数是一个特殊的函数,用于创建和初始化对象。

构造函数通过new关键字来调用,它会创建一个新的空对象,并将这个新对象作为构造函数的上下文(即this)来执行构造函数的代码。在构造函数中,我们可以定义对象的属性和方法。

下面是一个示例,展示了如何定义和使用构造函数:

javascript 复制代码
// 定义构造函数
function Person(name, age) {
  // 定义属性
  this.name = name;
  this.age = age;
  
  // 定义方法
  this.sayName = function() {
    console.log("My name is " + this.name);
  };
}

// 使用构造函数创建对象
var person1 = new Person("John", 25);
var person2 = new Person("Mary", 30);

// 访问对象属性
console.log(person1.name); // 输出: John
console.log(person2.age); // 输出: 30

// 调用对象方法
person1.sayName(); // 输出: My name is John
person2.sayName(); // 输出: My name is Mary

在上面的示例中,我们定义了一个名为Person的构造函数,它接受两个参数nameage。在构造函数内部,我们使用this关键字来定义对象的属性和方法。this.namethis.age分别表示对象的名字和年龄属性,this.sayName表示对象的sayName方法。

然后,我们使用new关键字来创建两个Person对象,并将它们分别赋值给person1person2变量。我们可以通过访问对象的属性来获取对象的属性值,通过调用对象的方法来执行对象的方法。

使用构造函数创建对象时,每个对象都有自己的属性和方法,这些属性和方法是独立的。这和使用对象字面量创建对象时,多个对象共享属性和方法的情况是不同的。

相关推荐
还是大剑师兰特6 分钟前
将 Utils.js 挂载为全局(window.Utils.xx)完整配置方案
开发语言·javascript·ecmascript
徐小夕17 分钟前
花了一周时间,我们开源了一款PDF编辑SDK,支持在线批注+脱敏
前端·vue.js·github
前端Hardy21 分钟前
Qwik 2.0 Beta 来了:不靠 AI,只靠 Resumability,首屏交互快到离谱
前端·javascript·面试
1-1=031 分钟前
ExtJS 快速入门—— 面板 详细版
前端·jquery
前端攻城狮Qwen32 分钟前
Service Worker在电子菜单中的实际应用
前端
前端Hardy34 分钟前
NW.js v0.109.1 最新稳定版发布:被遗忘的桌面开发神器?启动快 3 倍,内存省 70%!
前端·javascript·vue.js
Kath38 分钟前
[归档][2022-05-16]opensumi看码记录
前端
清风徐来QCQ1 小时前
跨域问题(CORS-Cross-Origin Resource Sharing跨域资源共享)
前端
DanCheOo1 小时前
我写了一个 AI 代码质量流水线,一行命令搞定 Review + 修复 + 测试 + 报告
前端·ai编程
yaaakaaang1 小时前
(六)前端,如此简单!--- 三类通讯
前端