摘要:和深入理解在和深入理解這篇博客里筆者曾做過總結,我們知道試單線程的產物,兩個函數就是利用了插入代碼的方式實現了偽異步,和的原理實際上是一樣的。綜上所述,其實終歸是單線程產物。無論如何異步都不可能突破單線程這個障礙。
說明:??這是筆者平時積累的一些覺得比較有意思或是比較有難度的JavaScript題目理解和心得,會保持長期更新。
1.setTimeout和setInterval深入理解在setTimeout和setInterval深入理解這篇博客里筆者曾做過總結,我們知道JavaScript試單線程的產物,兩個函數就是利用了插入代碼的方式實現了偽異步,和AJAX的原理實際上是一樣的。下面來看下這個例子:
console.log("1"); setTimeout(function(){ console.log("3") },0); console.log("2");
結果:控制臺依次輸出1,2,3;
function fn() { setTimeout(function(){alert("can you see me?");},1000); while(true) {} }
你覺得這段代碼的執行結果是什么呢?答案是,alert永遠不會出現。
????這是為什么呢?因為,while這段代碼沒有執行完,所以插入在后面的代碼便永遠不會執行。
綜上所述,其實JS終歸是單線程產物。無論如何“異步”都不可能突破單線程這個障礙。所以許多的“異步調用”(包括Ajax)事實上也只是“偽異步”而已。只要理解了這么一個概念,也許理解setTimeout和setInterval也就不難了。
在JavaScript閉包初探這篇博客里面進行了初步探討,有幾個小題個人覺得還是比較有意思的:
var name = "The Window"; var object = { name : "My Object", getNameFunc : function(){ return function(){ return this.name; }; } }; alert(object.getNameFunc()());//The Window
var name = "The Window"; var object = { name : "My Object", getNameFunc : function(){ var that = this; return function(){ return that.name; }; } }; alert(object.getNameFunc()());//My Object
function fun(n,o) { console.log(o) return { fun:function(m){ return fun(m,n); } }; } var a = fun(0); a.fun(1); a.fun(2); a.fun(3);//undefined,?,?,? var b = fun(0).fun(1).fun(2).fun(3);//undefined,?,?,? var c = fun(0).fun(1); c.fun(2); c.fun(3);//undefined,?,?,?
//問:三行a,b,c的輸出分別是什么?
這是一道非常典型的JS閉包問題。其中嵌套了三層fun函數,搞清楚每層fun的函數是那個fun函數尤為重要。
3. Array/map,Number/parseInt//答案:
//a: undefined,0,0,0
//b: undefined,0,1,2
//c: undefined,0,1,1
["1", "2", "3"].map(parseInt)//求輸出結果
??首先, map接受兩個參數, 一個回調函數 callback, 一個回調函數的this值
其中回調函數接受三個參數 currentValue, index, arrary;而題目中, map只傳入了回調函數--parseInt.其次, parseInt 只接受兩個兩個參數 string, radix(基數). radix的合法區間是2-36. 0或是默認是10.所以本題即問
parseInt("1", 0); parseInt("2", 1); parseInt("3", 2);
后兩者參數不合法.所以答案是:[1, NaN, NaN];
4.?0.1+0.2!=0.3和9999999999999999 == 10000000000000000;根據語言規范,JavaScript 采用“IEEE 754 標準定義的雙精度64位格式”("double-precision 64-bit format IEEE 754 values")表示數字。據此我們能得到一個有趣的結論,和其他編程語言(如 C 和 Java)不同,JavaScript 不區分整數值和浮點數值,所有數字在 JavaScript 中均用浮點數值表示,所以在進行數字運算的時候要特別注意。精度丟失看看下面的例子:
0.1 + 0.2 = 0.30000000000000004
在具體實現時,整數值通常被視為32位整型變量,在個別實現(如某些瀏覽器)中也以32位整型變量的形式進行存儲,直到它被用于執行某些32位整型不支持的操作,這是為了便于進行位操作。大整數精度在2的53次方以內是不會丟失的,也就是說瀏覽器能精確計算Math.pow(2,53)以內所有的數,小數精度,當十進制小數的二進制表示的有限數字不超過 52 位時,在 JavaScript 里也是可以精確存儲的。
解決辦法:Math.round( (.1+.2)*100)/100;
5. [1>2>3,3>2>1]??此題會讓人誤以為是2>1&&2<3,其實不是的,這個題等價于
1<2=>true; true<3=>1<3=>true; 3<2=>true; false<1=>0<1=>true;
答案:[true,true]
??這個題的重點是對于運算符的理解,一是javascript對于不同類型數值的比較規則,詳見js比較表,javascript相等性判斷;二是對于比較操作符和賦值運算符的理解,即一個自左向右一個自右向左~
3.tostring; 3..toString; 3...toString;
這個題感覺腦洞很大啊~先說答案:error,"3",error;
可如果是
var a=3; a.toString;
卻又合法了答案就是"3";
為啥呢?
因為在JS中1.1,1.,.1都是合法數字啊!那么在解析3.toString的時候到底是這是個數字呢,還是方法調用呢?瀏覽器就懵逼了唄,只能拋出一個error,所以說感覺此題就是在戲耍瀏覽器......
var name = "World!"; (function () { if (typeof name === "undefined") { var name = "Jack"; console.log("Goodbye " + name); } else { console.log("Hello " + name); } })();
答案是什么呢...筆者第一次做的時候傻傻的覺得是Hello,world...實則不然,正確答案是:Goodbye Jack;
為什么呢,聲明提升...上述代碼相當于下面的代碼:
var name = "World!"; (function () { var name; if (typeof name === "undefined") { name = "Jack"; console.log("Goodbye " + name); } else { console.log("Hello " + name); } })();8. 坑爹史(1)
var a = [0]; if ([0]) { console.log(a == true); } else { console.log("wut"); }
讀者們你們覺得此題答案是什么呢?true?因為[0]被看做Boolean是被認為是true,理所當然的推出來[0]==true,控制臺輸出true...看似沒錯,然而并不是這樣滴~[0]這個玩意兒在多帶帶使用的時候是被認為是true的,但用作比較的時候它是false...所以正確答案是false;不信的話,F12控制臺輸出[0]==false;看是不是true......
9. 坑爹史(2)1 + - + + + - + 1
這題應該是等同于:(倒著看)
1 + (a) => 2 a = - (b) => 1 b = + (c) => -1 c = + (d) => -1 d = + (e) => -1 e = + (f) => -1 f = - (g) => -1 g = + 1 => 1
答案是2
10. 坑爹史(3)function sidEffecting(ary) { ary[0] = ary[2]; } function bar(a,b,c) { c = 10 sidEffecting(arguments); return a + b + c; } bar(1,1,1)
此題涉及ES6語法,實在坑的不行...arguments
首先 The arguments object is an Array-like object corresponding to the arguments passed to a function.也就是說 arguments 是一個 object, c 就是 arguments[2], 所以對于 c 的修改就是對 arguments[2] 的修改.
所以答案是 21.
然而!!!!!!
當函數參數涉及到 any rest parameters, any default parameters or any destructured parameters 的時候, 這個 arguments 就不在是一個 mapped arguments object 了.....請看:
function sidEffecting(ary) { ary[0] = ary[2]; } function bar(a,b,c=3) { c = 10 sidEffecting(arguments); return a + b + c; } bar(1,1,1)
答案是12...
請讀者細細體會!!
[,,,].join(", ")
[,,,] => [undefined × 3]
因為javascript 在定義數組的時候允許最后一個元素后跟一個,, 所以這是個長度為三的稀疏數組(這是長度為三, 并沒有 0, 1, 2三個屬性哦)
答案: ", , "
var a = {class: "Animal", name: "Fido"}; a.class
這個題比較流氓.. 因為是瀏覽器相關, class是個保留字(現在是個關鍵字了);Fuck!
所以答案不重要, 重要的是自己在取屬性名稱的時候盡量避免保留字. 如果使用的話請加引號 a["class"]
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/79651.html
摘要:函數式編程前端掘金引言面向對象編程一直以來都是中的主導范式。函數式編程是一種強調減少對程序外部狀態產生改變的方式。 JavaScript 函數式編程 - 前端 - 掘金引言 面向對象編程一直以來都是JavaScript中的主導范式。JavaScript作為一門多范式編程語言,然而,近幾年,函數式編程越來越多得受到開發者的青睞。函數式編程是一種強調減少對程序外部狀態產生改變的方式。因此,...
摘要:說明你可能發現有很多網站他們的登錄窗口或者說是登錄框是可以拖動的更有甚者他們的站點提示框都可以拖動你也許可能會對這個功能的實現感興趣那么這篇文章可能會對你有所幫助具體的網站示例以網易云音樂站點為例,具體效果如下圖所示實現登錄窗口的拖拽原理解 說明 你可能發現有很多網站他們的登錄窗口或者說是登錄框是可以拖動的, 更有甚者他們的站點提示框都可以拖動, 你也許可能會對這個功能的實現感興趣, ...
摘要:填坑之旅篇填坑之旅動畫填坑之旅請求篇如果不能從頭到尾的建立一個應用,那么將失色不少。隨著,內置的支持了這個填補回調地獄大坑的功能。很好的利用了這一點,它的請求返回結果就是。在界面上顯示異常用,顯示警告使用。 React Native填坑之旅--Button篇React Native填坑之旅--動畫React Native填坑之旅--HTTP請求篇 如果不能從頭到尾的建立一個RN應用,那...
摘要:在中巧用解決跳轉到第三方平臺時不能回調的問題比如支付在開發中遇到不少的坑,絕大部分解決了但是在我們的中如果跳轉到第三方網站上時,那么問題來了此時我們的是不能監聽到你在其它網站上的事件的,所以當你想要回退到我們自己上時請緊握你的蛋小編在開發這 在ionic中巧用iframe解決跳轉到第三方平臺時不能回調的問題-比如支付 在ionic開發中遇到不少的坑,絕大部分解決了但是在我們的app...
摘要:寫插件的初衷項目經常需要無縫滾動效果,當時寫的時候用用這個老插件,相對不上很好用。后來轉向在沒有找到好的無縫滾動插件,除了配置可以實現但是相對來說太重了,于是自己造了個輪子。 寫插件的初衷 1.項目經常需要無縫滾動效果,當時寫jq的時候用用msClass這個老插件,相對不上很好用。2.后來轉向vue在vue-awesome沒有找到好的無縫滾動插件,除了配置swiper可以實現但是相對來...
閱讀 2569·2021-11-23 09:51
閱讀 2481·2021-09-30 09:48
閱讀 1076·2021-09-10 10:51
閱讀 2213·2021-08-12 13:22
閱讀 3568·2021-08-11 10:24
閱讀 2167·2019-08-30 15:55
閱讀 646·2019-08-30 14:05
閱讀 3211·2019-08-30 13:03