<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
JavaScript在不斷地升級迭代,越來越多的新特性讓我們的程式碼寫起來變得簡潔有趣,這篇文章會介紹5個新特性,一起研究一下把。
有時,我們想知道物件上是否存在某個屬性,一般會使用“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
以前,我們一般用_
表示私有屬性,但它並不靠譜,還是會被外部修改。
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
直接看例子,驚呆了我...
const sixBillion = 6000000000 // ❌ 難以閱讀 const sixBillion2 = 6000_000_000 // ✅ 更加易於閱讀 console.log(sixBillion2) // 6000000000
當然也可以使用"_"用於計算
const sum = 1000 + 6000_000_000 // 6000001000
這些例子,你一定非常熟悉,咱們有辦法可以簡化它嗎?
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
?. 的一般用法
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
希望能一直給大家分享實用、基礎、進階的知識點,一起早早下班,快樂摸魚,更多關於JavaScript新特性的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45