当前位置: 首页 > news >正文

js几种对象创建方式

适用于不确定对象内部数据

方式一:

var p = new Object();
p.name = 'TOM';
p.age = 12
p.setName = function(name) {
   this.name = name;
}

// 测试
p.setName('jack')
console.log(p.name,p.age)

方式二: 对象字面量模式

套路:使用{}创建对象,同时指定属性、方法

适用场景:起始时对象内部数据是确定的

问题:如果创建多个对象,有重复代码

var p = {
name: 'TOM',
age: 12,
  setName: function(name) {
    this.name = name;
  }
}

// 测试
console.log(p.name,p.age)// TOM 12
p.setName('JACK');
console.log(p.name,p.age)// JACK 12

如果创建多个对象,代码重复
var p2 = {
name: 'TOM',
age: 13,
  setName: function(name) {
    this.name = name;
  }
}
 

方式三:工厂模式

套路:通过工厂函数动态创建对象并返回

适用场景: 需要创建多个对象

问题: 对象没有一个具体的类型都是Object类型

function createPerson (name,age) {// 返回一个对象的函数=》 工厂函数
  var obj = {
     name: name,
     age: age,
     setName: function(name) {
       this.name = name;
     }
    }
   return obj
}

 var p1 = createPerson('Tom',12)
var p1 = createPerson('Jack',13)

方式四:自定义构造函数模式

套路: 自定义构造函数,通过new创建对象

适用场景: 需要创建多个类型确定得对象

问题: 每个对象都有相同得数据,消费内存

// 定义类型
  function Person(name,age) {
    this.name = name;
     this.age = age;
      this.setName = function(name) {
        this.name = name;
    }
}
var p1 = new Person('TOM',12)
P1.setName('JACK')
console.log(p1.name,p1.age)

方式六:构造函数+原型的组合模式

*套路: 自定义构造函数,属性在函数中初始化,方法添加到原型上

*适用场景:需要创建多个类型确定的对象

function Person(name,age) {
   // 在构造函数中只初始化一般函数
    this.name = name;
     this.age = age;
  Person.prototype.setName = function(name) {
     this.name = name;
    }
}
  var p1 = new Person('tom',12)
var p1 = createPerson('jack',13)
  console.log(p1,p2)

原文链接:

37.尚硅谷_JS高级_对象创建模式_哔哩哔哩_bilibili

相关文章:

  • Android TV UI开发常用知识
  • 【解锁技能】学会Python条件语句的终极指南!
  • 2023年“网络安全”赛项浙江省金华市选拔赛 任务书
  • 2023年全国最新二级建造师精选真题及答案9
  • 《金山区提信心扩需求稳增长促发展行动方案》的通知
  • 吉林大学 程序设计基础 2022级 实验复盘 2.23
  • 【Java】TCP网络编程(字节/符流)
  • Ubuntu 安装指定版本 Mysql,并设置远程连接(以安装mysql 5.5 为例)
  • STM32——毕设智能感应窗户
  • 前端面试题
  • 【LeetCode】剑指 Offer(11)
  • 华为OD机试模拟题 用 C++ 实现 - 寻找连续区间(2023.Q1)
  • 优雅的controller层设计
  • Echarts 每个柱子一种渐变色的象形柱状图
  • Liunx(狂神课堂笔记)
  • 2023软件测试工程师全新技术栈,吃透这些,起薪就是25k~
  • k8s新增节点机器,无法拉取和推送镜像的解决方案
  • AIX系统常见漏洞修复(exec、rlogin、rsh、ftp、telnet远端服务运行中)
  • 计算机组成原理(1)--计算机系统概论
  • 带你深入了解c语言指针后续
  • 对话地铁读书人|来自大学教授的科普:读书日也是版权日
  • 杭州一地铁口建筑被吐槽像棺材,官方回应:暂无拆除计划
  • 卡洛·金茨堡:女巫与萨满——我的学术之路
  • 世界最大直径高铁盾构机掘进至长江江心,安全穿越刀鲚保护区
  • 绿城中国5.39亿元竞得浙江台州住宅用地,刷新板块单价纪录
  • 锦州4名少年偷手机89部还发视频炫耀,店主:贼抓了又放,手机向谁要