博客 github 地址: https://github.com/HCThink/h-blog/blob/master/interesting/in1.md
github 首頁(yè)(star+watch,一手動(dòng)態(tài)直達(dá)): https://github.com/HCThink/h-blog
掘金 link , 掘金 專欄
segmentfault 主頁(yè)
原創(chuàng)禁止私自轉(zhuǎn)載
廣告部門長(zhǎng)期招收大量研發(fā)崗位【前端,后端,算法】,歡迎各位大神投遞,踴躍嘗試。
坐標(biāo): 頭條,大量招人,難度有降低,大多能拿到很不錯(cuò)的漲幅,未上市,offer 給力!歡迎騷擾郵箱!
戳我: 戳我: hooper.echo@gmail.com
注意: 如下代碼可能存在不可見部分: ,如果想看效果,務(wù)必 copy 源碼運(yùn)行, 而不要自己手敲
toString / valueOf : 最直接的方案let a = { i: 1, toString: function () { return a.i++; } }getter : 新式
var i = 0; with({ get a() { return ++i; } }) { if (a == 1 && a == 2 && a == 3) console.log("wohoo"); } // or Object.defineProperty(window, "a", { get: function() { return ++val; } }); // or window.__defineGetter__( "a", function(){ if( typeof i !== "number" ){ // define i in the global namespace so that it"s not lost after this function runs i = 0; } return ++i; });es6 Proxy
var a = new Proxy({ i: 0 }, { get: (target, name) => name === Symbol.toPrimitive ? () => ++target.i : target[name], }); console.log(a == 1 && a == 2 && a == 3);別具匠心
// This works because == invokes toString which calls .join for Arrays. a = [1,2,3]; a.join = a.shift; console.log(a == 1 && a == 2 && a == 3);新潮
// Another solution, using Symbol.toPrimitive which is an ES6 equivalent of toString/valueOf let a = {[Symbol.toPrimitive]: ((i) => () => ++i) (0)}; console.log(a == 1 && a == 2 && a == 3);amazed 最讓我吃驚的方案
var a? = 1; var a = 2; var ?a = 3; if(a? ==1 && a == 2 && ?a ==3) { console.log("Why hello there!") } // let a? = 1; // let a = 2; // let ?a = 3; // https://stackoverflow.com/questions/48270127/can-a-1-a-2-a-3-ever-evaluate-to-true# // 這里三個(gè)是不同的變量,第一個(gè)和第三個(gè) a 前后的空白字符不是空格,Unicode FFA0 // 請(qǐng)注意if 語(yǔ)句中的奇怪間距。它是半寬度韓文=,=。這是一個(gè) Unicode 空格字符,但是 ECMAScript 不將其解釋為一個(gè)空格 —— 這意味著它是一個(gè)有效的標(biāo)識(shí)符。因此有三個(gè)完全不同的變量,一個(gè)是a后加半寬度韓文,一個(gè)是a, 一個(gè)是a前加半寬度韓文。覆蓋式: 原理同上, if 后面有一個(gè)字符. 在 chrome 調(diào)試中可以看得到, 你沒法覆蓋掉真正的 if. 所以大括號(hào)必須新起一行
if?=()=>!0; var i = 1; if?(i == 1 && i == 2 && i == 3) { console.log(i) }拓展: 數(shù)字變量名
var a = 1; var ?1 = a; var ?2 = a; var ?3 = a; console.log( a ==?1 && a ==?2 && a ==?3 );
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/100375.html
小編寫這篇文章的主要目的,主要是講解一些關(guān)于python的事情,比如需要對(duì)圖片進(jìn)行批量壓縮,壓縮的方法還是比較的多的,那么,為了提高效率,怎么進(jìn)行批量壓縮呢?下面就給大家詳細(xì)解答下。 前言 最近在研究怎么對(duì)圖片資源進(jìn)行無(wú)損壓縮,網(wǎng)上也找了一些資料??偠灾?,收獲不少,所以想對(duì)最近的學(xué)習(xí)做個(gè)總結(jié)?! o(wú)損壓縮其實(shí)是相對(duì)而言的,目的是為了減小圖片資源的內(nèi)存大小但又不影響圖片的顯示質(zhì)量。下面我將...
今天主要就是匯總JavaScript數(shù)組的9中不同方法匯總,也將詳細(xì)示例展示給大家?! ∪绻氵€不知道數(shù)組實(shí)例中迭代方法有什么區(qū)別,可以看下面這張圖: map 代表返回一個(gè)新的數(shù)組,且數(shù)組中的每一項(xiàng)都是執(zhí)行過(guò)map提供的回調(diào)函數(shù)結(jié)果?! ?shí)現(xiàn)代碼如下: constmap=(array,fun)=>{ //類型約束 if(Object.prototype.toString.c...
本篇文章主要講述JS中l(wèi)et與const命令使用,通過(guò)代碼展示給各位?! et命令 基本使用 在ES6中,let命令是新增的聲明變量,與var的差異在于let無(wú)法重復(fù)聲明,且let有效只是在其命令的代碼塊內(nèi),let禁止變量出現(xiàn)變量提升現(xiàn)象,let的特點(diǎn)就是通過(guò)暫時(shí)性死區(qū)的方式來(lái)避免程序上的錯(cuò)誤 代碼塊:使用{}包括起來(lái)的內(nèi)容 聲明變量:分配一個(gè)存儲(chǔ)空間 不可重復(fù)聲明:let聲明過(guò)后...
小編寫這篇文章的主要目的,是給大家去做一個(gè)相關(guān)的介紹,介紹一下關(guān)于其怎么才能夠?qū)崿F(xiàn)python迷宮,那么,我們要使用的話,就要去生成代碼了,那么,具體的代碼有嗎?下面就給大家做一個(gè)解答?! ∽鳛橐豁?xiàng)古老的智力游戲,千百年來(lái)迷宮都散發(fā)著迷人的魅力。但是,手工設(shè)計(jì)迷宮費(fèi)時(shí)又耗(腦)力,于是,我們有必要制作一個(gè)程序:迷宮生成器…… 好吧,我編不下去了。但是,從上面的文字中,我們可以看出,我們此次的...
一、我們先說(shuō)說(shuō)javascript的作用域 ?、偃肿兞?函數(shù)體外部進(jìn)行聲明 ?、诰植孔兞?函數(shù)體內(nèi)部進(jìn)行聲明 1)函數(shù)級(jí)作用域 javascript語(yǔ)言中局部變量不同于C#、Java等高級(jí)語(yǔ)言,在這些高級(jí)語(yǔ)言內(nèi)部,采用的塊級(jí)作用域中會(huì)聲明新的變量,這些變量不會(huì)影響到外部作用域?! 《鴍avascript則采用的是函數(shù)級(jí)作用域,也就是說(shuō)js創(chuàng)建作用域的單位是函數(shù)?! ±纾骸 ≡贑#當(dāng)中我...
閱讀 3290·2021-11-23 09:51
閱讀 3633·2021-11-09 09:46
閱讀 3794·2021-11-09 09:45
閱讀 3023·2019-08-29 17:31
閱讀 1915·2019-08-26 13:39
閱讀 2775·2019-08-26 12:12
閱讀 3680·2019-08-26 12:08
閱讀 2286·2019-08-26 11:31