实例,原型,静态属性或方法

关于实例,原型,静态属性或方法如下:

// 实例、原型、静态属性或方法
// 一个函数是不是构造函数:取决于你怎么用
/* function App(name) {
  // 实例属性
  this.name = name
  // 实例方法
  this.showName = function () {
    console.log('Hello')
  }
}

const a = new App('ifer')
const b = new App('elser')
// console.log(a.name) // 'ifer'
console.log(a.showName === b.showName) // false */

/* function App(name) {
  // 实例属性
  this.name = name
}
// 原型属性
App.prototype.age = 18
// 原型方法
App.prototype.showName = function () {
  console.log('Hello')
}

const a = new App('ifer')
const b = new App('elser')
console.log(a.showName === b.showName) // true */

/* class App {
  constructor(name) {
    // 挂载 constructor 里面的是实例属性和方法
    this.name = name
    this.showName = function () {
      console.log('Hello')
    }
  }
}
const a = new App('ifer')
const b = new App('elser')
console.log(a.showName === b.showName) // false */

/* class App {
  constructor(name) {
    // !挂载 constructor 里面的是实例属性和方法
    this.name = name
  }
  // 原型方法
  showName() {
    console.log('Hello')
  }
}
const a = new App('ifer')
const b = new App('elser')
console.log(a.showName === b.showName) // true */

/* class App {
  constructor(name) {
    // !挂载 constructor 里面的是实例属性和方法
    this.name = name
  }
  // 实例属性
  state = {
    age: 18,
  }
  // 原型方法
  showName() {
    console.log('Hello')
  }
}
const a = new App('ifer')
const b = new App('elser')
console.log(a.state === b.state) // false,实例属性 */

/* class App {
  // !直接在 class 内部通过等号赋值的是挂载到实例上的
  showName = () => {
    console.log('Hello1')
  }
  // 原型方法
  showName() {
    console.log('Hello2')
  }
}
const a = new App('ifer')
const b = new App('elser')
// console.log(a.showName === b.showName) // false,实例属性
a.showName() // */

/* function App(name) {
  // 实例属性
  this.name = name
}
// 原型方法
App.prototype.showName = function () {}

// 静态属性方法:直接通过构造函数能访问的属性或方法称为静态属性或方法
App.version = 'xxx'

const a = new App()
console.log(a.version)
console.log(App.version) */

class App {
  // 静态属性
  static age = 18
}
App.age2 = 19
console.log(App.age)
console.log(App.age2)

// 多个对象之间通过 __proto__ 链接起来的这种关系就是原型链
// a => App => Object.prototype

什么是原型链?

简述的话就是 ---多个对象之间通过 __proto__ 链接起来的这种关系就是原型链

  a=>  app=>objeck.prototype
 实例=> 构造函数=> 原型

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Object的静态方法实例方法如下: 静态方法: 1. Object.assign():用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。 2. Object.create():用指定的原型对象和属性创建一个新对象。 3. Object.defineProperty():定义一个新属性或修改一个已有属性的特性。 4. Object.defineProperties():定义或修改一个或多个属性的特性。 5. Object.entries():返回一个给定对象自身可枚举属性的键值对数组。 6. Object.freeze():冻结一个对象,使其属性不可修改。 7. Object.fromEntries():将键值对列表转换为一个对象。 8. Object.getOwnPropertyDescriptor():获取指定对象上一个属性的描述符。 9. Object.getOwnPropertyDescriptors():返回一个对象的所有自身属性的描述符。 10. Object.getOwnPropertyNames():返回一个数组,包含指定对象的所有非继承可枚举属性的名称。 11. Object.getOwnPropertySymbols():返回一个数组,包含指定对象的所有Symbol属性的名称。 12. Object.getPrototypeOf():返回指定对象的原型。 13. Object.is():比较两个值是否相同。 14. Object.isExtensible():判断一个对象是否可扩展。 15. Object.isFrozen():判断一个对象是否已被冻结。 16. Object.isSealed():判断一个对象是否已被密封。 17. Object.keys():返回一个数组,包含指定对象的所有非继承可枚举属性的名称。 18. Object.preventExtensions():防止一个对象被扩展。 19. Object.seal():密封一个对象,使其属性不可删除或添加。 20. Object.setPrototypeOf():设置指定对象的原型实例方法: 1. Object.prototype.hasOwnProperty():判断一个对象是否含有指定的属性。 2. Object.prototype.isPrototypeOf():判断一个对象是否是另一个对象的原型。 3. Object.prototype.propertyIsEnumerable():判断一个属性是否可枚举。 4. Object.prototype.toLocaleString():返回对象的本地化字符串表示。 5. Object.prototype.toString():返回对象的字符串表示。 6. Object.prototype.valueOf():返回对象的原始值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值