中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript語法中12個需要繞開的陷阱分別是怎樣的

發布時間:2021-11-20 14:35:59 來源:億速云 閱讀:134 作者:柒染 欄目:web開發

今天就跟大家聊聊有關JavaScript語法中12個需要繞開的陷阱分別是怎樣的,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

12種應該避免的JavaScript語法,內容如下:

1. == 

Javascript有兩組相等運算符,一組是==和!=,另一組是===和!==。前者只比較值的相等,后者除了值以外,還比較類型是否相同。

請盡量不要使用前一組,永遠只使用===和!==。因為==默認會進行類型轉換,規則十分難記。如果你不相信的話,請回答下面五個判斷式的值是true還是false:

false == 'false'  false == undefined   false == null  null == undefined   0 == ''

前三個是false,后兩個是true。

2. with

with的本意是減少鍵盤輸入。比如

obj.a = obj.b;   obj.c = obj.d;

可以簡寫成

with(obj) {  a = b;  c = d;  }

但是,在實際運行時,解釋器會首先判斷obj.b和obj.d是否存在,如果不存在的話,再判斷全局變量b和d是否存在。這樣就導致了低效率,而且可能會導致意外,因此***不要使用with語句。

3. eval

eval用來直接執行一個字符串。這條語句也是不應該使用的,因為它有性能和安全性的問題,并且使得代碼更難閱讀。

eval能夠做到的事情,不用它也能做到。比如

eval("myValue = myObject." + myKey + ";");

可以直接寫成

myValue = myObject[myKey];

至于ajax操作返回的json字符串,可以使用官方網站提供的解析器json_parse.js運行。

4. continue

這條命令的作用是返回到循環的頭部,但是循環本來就會返回到頭部。所以通過適當的構造,完全可以避免使用這條命令,使得效率得到改善。

5. switch 貫穿

switch結構中的case語句,默認是順序執行,除非遇到break,return和throw。有的程序員喜歡利用這個特點,比如

switch(n) {  case 1:  case 2:  break;  }

這樣寫容易出錯,而且難以發現。因此建議避免switch貫穿,凡是有case的地方,一律加上break。

switch(n) {  case 1:  break;  case 2:  break;  }

6. 單行的塊結構

if、while、do和for,都是塊結構語句,但是也可以接受單行命令。比如

if (ok) t = true;

甚至寫成

if (ok)  t = true;

這樣不利于閱讀代碼,而且將來添加語句時非常容易出錯。建議不管是否只有一行命令,都一律加上大括號。

if (ok){  t = true;  }

7. ++和--

遞增運算符++和遞減運算符--,直接來自C語言,表面上可以讓代碼變得很緊湊,但是實際上會讓代碼看上去更復雜和更晦澀。因此為了代碼的整潔性和易讀性,不用為好。

8. 位運算符

Javascript完全套用了Java的位運算符,包括按位與&、按位或|、按位異或^、按位非~、左移<<、帶符號的右移>>和用0補足的右移>>>。

這套運算符針對的是整數,所以對Javascript完全無用,因為Javascript內部,所有數字都保存為雙精度浮點數。如果使用它們的話,Javascript不得不將運算數先轉為整數,然后再進行運算,這樣就降低了速度。而且“按位與運算符”&同“邏輯與運算符”&&,很容易混淆。

9. function語句

在Javascript中定義一個函數,有兩種寫法:

function foo() { }

var foo = function () { }

兩種寫法完全等價。但是在解析的時候,前一種寫法會被解析器自動提升到代碼的頭部,因此違背了函數應該先定義后使用的要求,所以建議定義函數時,全部采用后一種寫法。

10. 基本數據類型的包裝對象

Javascript的基本數據類型包括字符串、數字、布爾值,它們都有對應的包裝對象String、Number和Boolean。所以,有人會這樣定義相關值:

new String("Hello World");   new Number(2000);   new Boolean(false);
  • 詳解Javascript中checkbox樹的功能

  • 對決JavaScript HTML5腳本API預覽

  • Javascript和CSS菜單推薦13條

  • 探秘Google的JavaScript開發工具Closure

  • JavaScript將增加本地操作API 可直接操作

這樣寫完全沒有必要,而且非常費解,因此建議不要使用。

另外,new Object和new Array也不建議使用,可以用{}和[]代替。

11. new語句

Javascript是世界上***個被大量使用的支持Lambda函數的語言,本質上屬于與Lisp同類的函數式編程語言。但是當前世界,90%以上的程序員都是使用面向對象編程。為了靠近主流,Javascript做出了妥協,采納了類的概念,允許根據類生成對象。

類是這樣定義的:

var Cat = function (name) {  this.name = name;  this.saying = 'meow' ;  }

然后,再生成一個對象

var myCat = new Cat('mimi');

這種利用函數生成類、利用new生成對象的語法,其實非常奇怪,一點都不符合直覺。而且,使用的時候,很容易忘記加上new,就會變成執行函數,然后莫名其妙多出幾個全局變量。所以,建議不要這樣創建對象,而采用一種變通方法。

Douglas Crockford給出了一個函數:

Object.beget = function (o) {  var F = function (o) {};  F.prototype = o ;  return new F;  };

創建對象時就利用這個函數,對原型對象進行操作:

var Cat = {  name:'',  saying:'meow' };   var myCat = Object.beget(Cat);

對象生成后,可以自行對相關屬性進行賦值:

myCat.name = 'mimi';

12. void

在大多數語言中,void都是一種類型,表示沒有值。但是在Javascript中,void是一個運算符,接受一個運算數,并返回undefined。

void 0; // undefined

這個命令沒什么用,而且很令人困惑,建議避免使用。

看完上述內容,你們對JavaScript語法中12個需要繞開的陷阱分別是怎樣的有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

梁河县| 永顺县| 南郑县| 营山县| 淮阳县| 南康市| 商城县| 淮北市| 东光县| 郸城县| 尉氏县| 教育| 丽江市| 奉节县| 江西省| 多伦县| 安岳县| 定襄县| 洪江市| 绿春县| 长治市| 桂阳县| 顺平县| 寻乌县| 将乐县| 株洲市| 正阳县| 合江县| 饶平县| 邻水| 鹿邑县| 五指山市| 华池县| 商洛市| 荆州市| 鸡东县| 林芝县| 沾化县| 汾阳市| 金阳县| 托克托县|