成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

五個一定要學會的 JavaScript 新特性

開發(fā) 前端
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 = { age: 24 }
Object.hasOwn(object, 'age') // true
let object2 = Object.create({ age: 24 })
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) 執(zhí)行函數

5. 使用"BigInt"支持大數計算

JS中超過“Number.MAX_SAFE_INTEGER”的數字計算將是不安全的。

Example:

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

使用"BigInt"完全可以避免這個問題

BigInt(Math.pow(2, 53)) === BigInt(Math.pow(2, 53)) + BigInt(1) // false
責任編輯:龐桂玉 來源: 前端大全
相關推薦

2021-04-27 22:32:18

Python

2021-12-14 22:16:58

電腦優(yōu)化設置

2023-02-26 23:23:36

CSS開發(fā)Web

2019-12-25 14:03:42

JavaScript開發(fā)

2019-12-25 09:00:00

JavascriptWeb前端

2018-12-28 14:16:11

安全

2020-09-08 14:05:06

Redis數據庫緩存

2010-11-19 16:02:42

IT族

2019-12-27 16:10:53

前端javascriptnode.js

2018-12-27 14:21:31

https安全http

2019-11-15 14:00:39

HTTPSHTTP前端

2017-10-16 12:52:51

2018-04-28 09:02:14

Chrome瀏覽器語言

2023-05-29 08:25:28

2022-08-31 09:35:26

Pycharm插件

2016-04-26 10:41:01

2022-04-27 07:21:06

HTTPAPI系統

2016-12-12 15:28:01

蘋果移動開發(fā)者

2019-05-17 14:55:08

優(yōu)化圖形差距

2012-11-01 11:11:36

Web設計Web設計
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91社区视频 | 欧美aaa一级片 | 日韩欧美在线一区二区 | 91九色porny首页最多播放 | av大全在线观看 | 日韩视频中文字幕 | 久久亚洲视频网 | 亚洲免费人成在线视频观看 | 亚洲精品久久久久avwww潮水 | 色性av | 国产精品一区二区av | 国产精品久久久久久久久 | 福利一区在线观看 | www久久久| 色综合久 | 欧美乱做爰xxxⅹ久久久 | 一区二区三区视频播放 | 国产精品美女久久久久久免费 | 欧美黄在线观看 | 久久久久亚洲 | 精品视频一区二区三区在线观看 | 日韩a在线 | 天天色天天 | av影片在线 | 成年人免费在线视频 | 久草新在线 | 日韩在线成人 | 欧美久久一区二区 | 国产探花在线精品一区二区 | 日本a∨精品中文字幕在线 亚洲91视频 | 亚洲国产一区二区三区 | 资源首页二三区 | 中文字幕一区二区三区乱码在线 | 亚洲天堂一区二区 | 成av在线| 精品1区2区3区4区 | 色综合天天综合网国产成人网 | 欧美精品中文字幕久久二区 | 韩国久久| 97精品久久 | 福利网址|