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变量。我们可以通过访问对象的属性来获取对象的属性值,通过调用对象的方法来执行对象的方法。

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

相关推荐
华玥作者13 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_14 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠14 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog14 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang2015092814 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC15 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务15 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_2474386115 小时前
Android ViewModel定时任务
android·开发语言·javascript
嘿起屁儿整16 小时前
面试点(网络层面)
前端·网络
VT.馒头16 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript