JavaScript編程開發(fā)中的五個實用小技巧
更新時間:2010年07月22日 00:58:01 作者:
下面的5點說明確實不錯,提高性能與可讀性,大家可以根據(jù)需要選擇使用。
真是五個很quick的小提示:
只在<form>元素上使用submit事件
如果要在form中綁定事件處理程序時,應該只在<form>元素上綁定submit事件,而不是給提交按鈕綁定click事件。
March:這個方式固然很好,但是,公司開發(fā)時使用了Web Flow,一個頁面就一個大form,而里面可能有若干個提交按鈕,所以不得不把部分事件處理程序綁定在了提交按鈕的click事件上。
可點擊的都應該是鏈接
不要給除錨元素(<a>)以外的元素綁定click事件。這一點對于鍵盤用戶很重要,因為他們在僅通過鍵盤獲取元素焦點時會遇到困難。
March:不過個人感覺錨元素還是應該只用作鏈接,而一些功能性的操作(比如Google Reader的Mark all as new),最好還是用<span>來標注,accessibility的問題可以通過快捷鍵等方式解決。這樣做可以更好的還原HTML元素的語義。
簡單的for循環(huán)優(yōu)化
在你寫一個for循環(huán)時,有個很簡單的技巧能夠提高性能。
使用下面的語句代替上面的:
這樣可以把元素的個數(shù)(elements.length的值)儲存在一個變量j中,這樣就不必在每次循環(huán)時都計算一遍元素的個數(shù)。
用匿名函數(shù)來作為事件處理程序
尤其是對于短小的函數(shù),創(chuàng)建一個匿名函數(shù)會比使用一個命名函數(shù)的引用更具可讀性。
March:在較復雜的JavaScript開發(fā)時還是使用命名函數(shù)效率更高。
使用Array.join代替字符串連接(concatenating strings)
在將很多字符串、變量等連接成一個很長的字符串時,將所有字符串和變量放入一個數(shù)組,然后用join方法將他們組成一個長字符串,這樣無論從代碼可讀性還是從性能上都更勝于字符串連接。
var text = 'There are' + elements.length + 'members in the elements array.';
var text = ['There are', elements.length, 'members in the elements array.'].join(' ');
只在<form>元素上使用submit事件
如果要在form中綁定事件處理程序時,應該只在<form>元素上綁定submit事件,而不是給提交按鈕綁定click事件。
March:這個方式固然很好,但是,公司開發(fā)時使用了Web Flow,一個頁面就一個大form,而里面可能有若干個提交按鈕,所以不得不把部分事件處理程序綁定在了提交按鈕的click事件上。
可點擊的都應該是鏈接
不要給除錨元素(<a>)以外的元素綁定click事件。這一點對于鍵盤用戶很重要,因為他們在僅通過鍵盤獲取元素焦點時會遇到困難。
March:不過個人感覺錨元素還是應該只用作鏈接,而一些功能性的操作(比如Google Reader的Mark all as new),最好還是用<span>來標注,accessibility的問題可以通過快捷鍵等方式解決。這樣做可以更好的還原HTML元素的語義。
簡單的for循環(huán)優(yōu)化
在你寫一個for循環(huán)時,有個很簡單的技巧能夠提高性能。
復制代碼 代碼如下:
for ( var i = 0; i < elements.length; ++i )
使用下面的語句代替上面的:
復制代碼 代碼如下:
for ( var i = 0, j = elements.length; i < j; ++i )
這樣可以把元素的個數(shù)(elements.length的值)儲存在一個變量j中,這樣就不必在每次循環(huán)時都計算一遍元素的個數(shù)。
用匿名函數(shù)來作為事件處理程序
尤其是對于短小的函數(shù),創(chuàng)建一個匿名函數(shù)會比使用一個命名函數(shù)的引用更具可讀性。
復制代碼 代碼如下:
anchor.onclick = function() { map.goToPosition( home ); return false; }
March:在較復雜的JavaScript開發(fā)時還是使用命名函數(shù)效率更高。
使用Array.join代替字符串連接(concatenating strings)
在將很多字符串、變量等連接成一個很長的字符串時,將所有字符串和變量放入一個數(shù)組,然后用join方法將他們組成一個長字符串,這樣無論從代碼可讀性還是從性能上都更勝于字符串連接。
復制代碼 代碼如下:
var text = 'There are' + elements.length + 'members in the elements array.';
var text = ['There are', elements.length, 'members in the elements array.'].join(' ');
相關文章
使用JavaScript 實現(xiàn)時間軸與動畫效果的示例代碼(前端組件化)
這篇文章主要介紹了使用JavaScript 實現(xiàn)時間軸與動畫效果的示例代碼(前端組件化),本文重點給大家介紹基礎的動畫類實現(xiàn)時間軸,通過示例代碼給大家介紹的很詳細,需要的朋友可以參考下2021-04-04寫了10年的Javascript也未必全了解的連續(xù)賦值運算
很喜歡 蔡蔡 的這個標題,實際蔡蔡已經(jīng)分析過了,這里借用了?;蛟S有點標題黨的意思??赐昃椭恕?/div> 2011-03-03最新評論