在JavaScript中遭遇級聯運算式陷阱

來源:互聯網
上載者:User

依稀還記得,在學習C語言的庫函數時,很多字串操作相關的函數都會返回和結果相關的指標。其實這個傳回值很多時候都並不是非常必要,因為在我們的傳入的參數中,十有八九已包含了這個指標。而加上這個傳回值的最大好處就是,可以讓我們方便的書寫出級聯運算式。但是這些年的實際工作中,越發覺得級聯運算式是個魔鬼餡餅。

比如在C語言中,我們熟悉的字串操作函數strcpy,strcat等,它們的原形一般是: extern char *strxxx(char *dest, char *src);
傳回值char*其實就是調用參數中的*dest,這樣一來就可以方便的寫出級聯運算式,如下:
char *title = "Mr. ";
char *name = "birdshome";
int len = strlen(strcat(title, name));
在物件導向編程中,通過方法返回對象,我們可以編寫鏈式運算式。雖然不管是級聯運算式也好,還是鏈式運算式也好,都可以讓我們在編寫代碼的方便一些,不過如果使用不當,也會非常鬱悶。特別是對於級聯運算式,如果函數嵌套過多,不易理解不說,debug也會很鬱悶。

下面這個JavaScript的級聯語句,就讓我鬱悶了很久。。。 dimInfo.push(StringHelper.ArrayToString(item.m_DimensionName,
item.m_DimensionUniqueName, item.m_AnalysisStatus,
(item.m_IsParameterized ? 'checked' : ''), item.m_DimensionType), levelTypes);
而正確的語句因該是下面這個: dimInfo.push(StringHelper.ArrayToString(item.m_DimensionName,
item.m_DimensionUniqueName, item.m_AnalysisStatus,
(item.m_IsParameterized ? 'checked' : ''), item.m_DimensionType, levelTypes));
問題就出在倒數第二個括弧上")"上,本來這個括弧應該在參數levelTypes之後,結果沒有注意弄到了levelTypes前面去了,這種書寫上的錯誤,要一眼看出來很難很難。更鬱悶的是,JavaScript對函數的參數個數,以及有沒有參數都一點不感興趣,所以這個錯誤的語句完全可以運行"正常",只是資料傳到後台後,怎麼也得不到需要的值,總是undefined。

另外,還有複合參數調用的語句,如果能適當的展開也會給我們帶來很多好處,比如代碼:
var rect = dashboard.getBoundingClientRect();
this.InsertNewRoom(dashboard, event.clientX-rect.left-1, event.clientY-rect.top, event);
將複合參數展開後的代碼為: var rect = dashboard.getBoundingClientRect();
var innerX = event.clientX-rect.left-1;
var innerY = event.clientY-rect.top;
this.InsertNewRoom(dashboard, innerX, innerY, event);
雖然這個展開的代碼沒有添加任何額外的邏輯,但是添加了臨時變數innerX和innerY的語句顯然比複合參數的語句要易於理解的多。這樣代碼雖然多了,但是卻使代碼有了self-documented特性,同時也沒有改變代碼的邏輯和效率。我相信在debug或者修改別人的代碼時,你是希望看到後一種寫法的。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.