自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

大挑戰(zhàn)!JS前端知識闖關(guān),你過得了幾關(guān)?

開發(fā) 前端
位運算符將數(shù)字視為32位的有符號整數(shù),而32位整數(shù)的取值范圍是 -2147483648 ~ 2147483647。

[[430004]]

本文轉(zhuǎn)載自微信公眾號「云的程序世界」,作者云的世界 。轉(zhuǎn)載本文請聯(lián)系云的程序世界公眾號。

前言

基礎(chǔ)知識真有趣,10個基礎(chǔ)知識的題目,請君來戰(zhàn)!

1. a.x = a = {n:2}

  1. var a = {n:1}; 
  2. a.x = a = {n:2}; 
  3.  
  4. // 求a.x 
  5. alert(a.x);  

解析

JavaScript 總是嚴(yán)格按照從左至右的順序來計算表達(dá)式。

  1. var a = {n:1}, ref = a; 
  2. a.x = a = {n:2}; 
  3. console.log("a:", a);  
  4. console.log("ref:",ref); 

2. 按位或取整數(shù)部分

求值:

  1. 100.8 | 0    
  2. -101.6 | 0    
  3. 8589934592.8 | 0 

解析

位運算符將數(shù)字視為32位的有符號整數(shù),而32位整數(shù)的取值范圍是 -2147483648 ~ 2147483647。

超過32位有符號整數(shù)范圍取值的數(shù),進(jìn)行位或操作取整都是不準(zhǔn)確的。

  1.  2147483647.1 | 0  //  2147483647 正確 
  2.  2147483648.1 | 0  // -2147483648 錯誤 
  3. -2147483648.1 | 0  // -2147483648 正確 
  4. -2147483649.1 | 0  //  2147483647 錯誤 

同樣的,我們可以用~~來取整數(shù)部分, 當(dāng)然依舊存在超范圍就不準(zhǔn)確的問題。

  1. ~~ 100.8 // 100  正確 
  2. ~~ 2147483649.1  // -2147483647  錯誤 

答案

  1. 100.8 | 0    // 100 
  2. -101.6 | 0   // -101 
  3. 8589934592.8 | 0  // 0 

3. 神奇的eval

  1. var x = "global"
  2. function log1(){ 
  3.     var x = "local"
  4.     return eval("x"
  5.  
  6. function log2(){ 
  7.     var x = "local"
  8.     return window.eval("x"
  9.  
  10. function log3(){ 
  11.     var x = "local"
  12.     var fn = eval 
  13.     return fn("x"
  14.  
  15. function log4(){ 
  16.     var x = "local"
  17.     return (0, eval)(x) 
  18.  
  19. log1(); 
  20. log2(); 
  21. log3(); 
  22. log4(); 

解析

eval函數(shù)具備訪問調(diào)用它那是的整個作用域的能力。

間接調(diào)用, 例如綁定eval函數(shù)到另外一個變量名,通過變量名調(diào)用函數(shù)會使代碼失去去所有局部作用域訪問的能力。

(0, eval) 其也是eval的間接調(diào)用。

  1. log1();   // local 
  2. log2();   // global 
  3. log3();   // global 
  4. log4();   // global 

答案

4. delete知多少

  1. delete null
  2. delete undefined; 

解析

undefined在實現(xiàn)上是一個全局屬性, 而null是一個關(guān)鍵字。

  1. Oject.getOwnPropertyDescriptor(global'undefined'
  2. 復(fù)制代碼 

截圖_20212014102047.png

null在全局上卻查詢不到描述信息:

  1. Object.getOwnPropertyDescriptor(global'null'

截圖_20212114102114.png

結(jié)果

  1. delete null; // true 
  2. delete undefined; // false 

5. 類型轉(zhuǎn)換

  1. function Person(name, age) { 
  2.     this.name = name
  3.     this.age = age; 
  4. Person.prototype.valueOf = function () { 
  5.     return this.age; 
  6. Person.prototype.toString = function () { 
  7.     return this.name 
  8. Date.prototype.valueOf = function () { 
  9.     return this.getTime() 
  10. Date.prototype.toString = function () { 
  11.     return this.getTime() + "" 
  12.  
  13. var person = new Person("tom", 100); 
  14. console.log(person + 10); 
  15. console.log(`${person}`) 
  16. console.log("" + person) 
  17.  
  18. var date = new Date(2001, 0, 0); 
  19. console.log(date + 0, typeof (date + 0)) 
  20. console.log(date + date.getTime()); 

分析

對象轉(zhuǎn)換成基礎(chǔ)數(shù)據(jù)類型

  • Symbol.toPrimitive 優(yōu)先
  • 如果預(yù)期轉(zhuǎn)為字符串,Object.prototype.toString
  • 如果無預(yù)期轉(zhuǎn)為字符串, 先走 Oject.prototye.valueOf, 再走Object.prototype.toString, 特例是Date類型,是先toString,再valueOf

注意兩點

  1. 預(yù)期轉(zhuǎn)為字符串這種字樣, 比如 `${person}`
  2. Date是特別的,是優(yōu)先toString

結(jié)果

  1. var person = new Person("tom", 100);  
  2. console.log(person + 10);  // 110 
  3. console.log(`${person}`)   // tom 
  4. console.log("" + person)   // 100 
  5.  
  6. var date = new Date(2001, 0, 0); 
  7. console.log(date + 0, typeof (date + 0))  
  8. // 9781920000000 string 
  9. console.log(date + date.getTime()); 
  10. // 978192000000978192000000 

6. 函數(shù)的length

  1. function add(num1, num2, num3=1, ...args){  
  2. const boundAdd = add.bind(null, 10); 
  3. console.log(boundAdd.length) 

問題解析

  • 有默認(rèn)值的參數(shù),不計入長度
  • 剩余參數(shù)不計入長度
  • bind之后,減少對應(yīng)的length長度

答案

  1. console.log(boundAdd.length) // 1 

7. this的指向

  1. var value = 1; 
  2.  
  3. var foo = { 
  4.   value: 2, 
  5.   bar: function () { 
  6.     return this.value; 
  7.   } 
  8.  
  9. console.log(foo.bar()); 
  10. console.log((foo.bar)()); 
  11. console.log((foo.bar = foo.bar)()); 
  12. console.log((false || foo.bar)()); 
  13. console.log((foo.bar, foo.bar)()); 

解析

ES規(guī)范中,引用類型(Reference類型)有一個獲取對應(yīng)值的方法:GetValue。簡單模擬 GetValue 的使用:

  1. var foo = 1; 
  2.  
  3. var fooReference = { 
  4.     base: EnvironmentRecord, 
  5.     name'foo'
  6.     strict: false 
  7. }; 
  8.  
  9. GetValue(fooReference) // 1; 

GetValue 返回對象屬性真正的值,但是要注意:調(diào)用 GetValue,返回的將是具體的值,而不再是一個 Reference

本題目如果調(diào)用了 GetValue, 那么其作用域就變成了全局。

(foo.bar) 并沒有調(diào)用取值操作,而其余的均調(diào)用了取值操作。

更多詳情:JavaScript深入之從ECMAScript規(guī)范解讀this[1]

答案

  1. console.log(foo.bar());   // 2 
  2. console.log((foo.bar)());  // 2 
  3. console.log((foo.bar = foo.bar)());  // 1 
  4. console.log((false || foo.bar)());   // 1 
  5. console.log((foo.bar, foo.bar)());   // 1 

8.參數(shù)傳遞

  1. function test(param1, param2, param3) { 
  2.     param1 = "new param1"
  3.     param3  = "new param3" 
  4.  
  5.     console.log(param1 == arguments[0]); 
  6.     console.log(param3 == arguments[2]); 
  7.  
  8.  
  9. function test_strict(param1, param2, param3) { 
  10.     "use strict" 
  11.     param1 = "new param1"
  12.     param3  = "new param3" 
  13.  
  14.     console.log(param1 == arguments[0]); 
  15.     console.log(param3 == arguments[2]); 
  16.  
  17. test('param1''param2'
  18. test_strict('param1''param2'); 

解析

非嚴(yán)格模式下:傳入的參數(shù),實參和 arguments 的值會共享,當(dāng)沒有傳入時,實參與 arguments 值不會共享。

嚴(yán)格模式下,實參和 arguments 是不會共享的。

答案

  1. test('param1''param2'
  2. test_strict('param1''param2'); 
  3. // true 
  4. // false 
  5. // false 
  6. // false 

9. 小數(shù)相加

  1. (0.1 + 0.2) + 0.3  === 0.1 + 0.2 + 0.3  

解析

簡略的回答就是精確問題。

更多的回答 IEEE 754, 雙精度浮點數(shù)(64位),使用1為符號位、11位指數(shù)位、52位尾數(shù)位來表示。

借助:http://www.binaryconvert.com/result_double.html

  1. 0.1 0-01111111011-1001100110011001100110011001100110011001100110011010 
  2. 0.2 0-01111111100-1001100110011001100110011001100110011001100110011010 
  3. 0.3 0-01111111101-0011001100110011001100110011001100110011001100110011 

當(dāng)然,計算還好好幾個步驟

  • 對階(大階對小階)
  • 位數(shù)運算
  • 結(jié)果規(guī)格化
  • 舍入處理
  • 移除檢查 當(dāng)然,本題,后面兩項都不存在。具體細(xì)節(jié),改篇文章再見!

答案

  1. (0.1 + 0.2) + 0.3  === 0.1 + 0.2 + 0.3  // false 
  2.  
  3. 0.6000000000000001 === 0.6 // false 

10. 自動補全

如下代碼輸出的值

  1. var a = [[1,2],2,3] 
  2. console.log(a) 
  3. [0,2,3].map(v=> console.log(v*v)) 
  4. console.log(a) 

解析

javascript能智能的插入分號,但是有5個有問題的字符需要密切的注意:(,[, +, -, /, 其作為一行代碼的開頭,很可能產(chǎn)生意外的情況,所以,沒事代碼最后寫個分號,保準(zhǔn)沒錯。

答案

 

責(zé)任編輯:武曉燕 來源: 云的程序世界
相關(guān)推薦

2017-06-23 18:00:22

前端知識雜談

2020-03-06 10:36:21

JavaScriptCSSHTML

2015-09-17 10:48:17

Web前端

2021-06-07 07:01:43

js關(guān)鍵字運行

2023-02-22 16:33:04

前端JavaScript

2018-08-28 09:42:21

緩存愛奇藝架構(gòu)

2019-11-13 13:48:32

前端CSS技術(shù)

2013-07-09 15:04:17

程序員編程

2020-09-02 07:00:42

ZooKeeper分布式

2019-07-17 13:31:34

VLAN集中管理協(xié)議VCMP

2016-12-21 15:43:30

SaaSC端盈利

2015-11-20 13:17:23

世紀(jì)互聯(lián)藍(lán)云Azure

2021-08-11 08:16:02

springboot 動態(tài)注冊項目

2018-10-09 14:34:58

開源KubernetesGit

2022-04-10 10:42:44

CSS前端前端布局

2012-02-08 08:44:22

2020-07-31 13:35:34

Node.js應(yīng)用分析前端

2017-12-15 21:05:13

2021-01-04 09:00:00

JavaScript開發(fā)Web

2021-05-17 11:14:26

前端HTTP服務(wù)器
點贊
收藏

51CTO技術(shù)棧公眾號