杭州IT培训
美国上市IT培训机构

400-111-8989

5个要学会的JavaScript新特性

  • 时间:2022-10-21 15:56
  • 发布:互联网
  • 来源:精品干货

前言

JavaScript在不断地升级迭代,越来越多的新特性让我们的代码写起来变得简洁有趣,这篇文章会介绍5个新特性,一起研究一下把。

1.# 使用"Object.hasOwn"替代“in”操作符


有时,我们想知道对象上是否存在某个属性,一般会使用“in”操作符或“obj.hasOwnProperty”,但它们都有各自的缺陷。

in

如果指定的属性位于对象或其原型链中,“in”运算符将返回true。

const Person = function (age{
  this.age = age
}
Person.prototype.name = 'fatfish' const p1 = new Person(24) console.log('age' in p1) // true  console.log('name' in p1) // true  注意这里 

obj.hasOwnProperty

hasOwnProperty 方法会返回一个布尔值,表示对象自身属性中是否具有对应的值(原型链上的属性不会读取)。

const Person = function (age{
  this.age = age
}
Person.prototype.name = 'fatfish' const p1 = new Person(24) console.log(p1.hasOwnProperty('age')) // true  console.log(p1.hasOwnProperty('name')) // fasle  注意这里 

obj.hasOwnProperty已经可以过滤掉原型链上的属性,但在某些情况下,它还是不安全。

Object.create(null).hasOwnProperty('name') // Uncaught TypeError: Object.create(...).hasOwnProperty is not a function 

Object.hasOwn

别急,我们可以使用Object.hasOwn来避免这两个问题,这比“obj.hasOwnProperty”方法更加方便、安全。

let object = { age24 } Object.hasOwn(object, 'age'// true let object2 = Object.create({ age24 }) Object.hasOwn(object2, 'age'// false   let object3 = Object.create(null) Object.hasOwn(object3, 'age'// false  


2.# 使用"#"声明私有属性


以前,我们一般用_表示私有属性,但它并不靠谱,还是会被外部修改。

class Person {
  constructor (name) {
    this._money = 1     this.name = name
  }
  get money () {
    return this._money
  }
  set money (money) {
    this._money = money
  }
  showMoney () {
    console.log(this._money)
  }
} const p1 = new Person('fatfish') console.log(p1.money) // 1 console.log(p1._money) // 1 p1._money = 2 // 依旧可以从外部修改_money属性,所以这种做法并不安全 console.log(p1.money) // 2 console.log(p1._money) // 2 

使用“#”实现真正私有属性

class Person {
  #money=1   constructor (name) {
    this.name = name
  }
  get money () {
    return this.#money
  }
  set money (money) {
    this.#money = money
  }
  showMoney () {
    console.log(this.#money)
  }
} const p1 = new Person('fatfish') console.log(p1.money) // 1 // p1.#money = 2 // 没法从外部直接修改 p1.money = 2 console.log(p1.money) // 2 console.log(p1.#money) // Uncaught SyntaxError: Private field '#money' must be declared in an enclosing class 


3.# 超有用的"数字分隔符"


直接看例子,惊呆了我...

const sixBillion = 6000000000 // ❌ 难以阅读 const sixBillion2 = 6000_000_000 // ✅ 更加易于阅读 console.log(sixBillion2) // 6000000000 

当然也可以使用"_"用于计算

const sum = 1000 + 6000_000_000 // 6000001000 


4.# 使用 ?. 简化 && 和 三元运算符


这些例子,你一定非常熟悉,咱们有办法可以简化它吗?

const obj = null console.log(obj && obj.name) const $title = document.querySelector('.title') const title = $title ? title.innerText : undefined 

“?.”

const obj = null console.log(obj?.name) const $title = document.querySelector('.title') const title = $title?.innerText 

Tips

?. 的一般用法

  1. obj?.prop 对象属性
  2. obj?.[expr] 对象属性
  3. func?.(...args) 执行函数


5.# 使用"BigInt"支持大数计算


JS中超过“Number.MAX_SAFE_INTEGER”的数字计算将是不安全的。

Example:

Math.pow(253) === Math.pow(253) + 1 // true // Math.pow(2, 53) => 9007199254740992 // Math.pow(2, 53) + 1 => 9007199254740992 

使用"BigInt"完全可以避免这个问题

BigInt(Math.pow(253)) === BigInt(Math.pow(253)) + BigInt(1// false

预约申请免费试听课

怕钱不够?就业挣钱后再付学费!    怕学不会?从入学起,达内定制课程!     担心就业?达内多家实践企业供你挑选 !

【免责声明】本文部分系转载,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与联系我们,我们会予以更改或删除相关文章,以保证您的权益!"
上一篇:程序员的工资是其他工作能够超越的嘛
下一篇:Java 19 已至,虚拟线程 = 王炸!!

Java 后端有哪些不用学的技术?

分布式存储之数据切片

策略模式:巧妙替代你的if-else

sorted()之正序倒序

Copyright © 2023 Tedu.cn All Rights Reserved 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有

选择城市和中心
江西省

贵州省

广西省

海南省