一些相見恨晚的 JavaScript 技巧

來源:互聯網
上載者:User

JavaScript 的成功讓人津津樂道,為 Web 網頁編寫 JavaScript 代碼已經是所有 Web 設計師的基本功,這門有趣的語言蘊藏著許多不為人熟知的東西,即使多年的 JavaScript 程式員,也未能完全吃透。本文從7個方面講述 JavaScript 中那些你不很熟知但非常實用的技巧。
簡略語句
JavaScript 可以使用簡略語句快速建立對象和數組,比如下面的代碼: 複製代碼 代碼如下:var car = new Object();
car.colour = 'red';
car.wheels = 4;
car.hubcaps = 'spinning';
car.age = 4;

可以使用簡略語句如下: 複製代碼 代碼如下:var car = {
colour:'red',
wheels:4,
hubcaps:'spinning',
age:4
}

對象 car 就此建立,不過需要特別注意,結束花括弧前一定不要加 ";" 否則在 IE 會遇到很大麻煩。
建立數組的傳統方法是: 複製代碼 代碼如下:var moviesThatNeedBetterWriters = new Array(
'Transformers','Transformers2','Avatar','Indiana Jones 4'
);

使用簡略語句則:

複製代碼 代碼如下:var moviesThatNeedBetterWriters = [
'Transformers','Transformers2','Avatar','Indiana Jones 4'
];

關於數組的另一個問題是有沒有一個關聯陣列這樣的東西。你會發現很多的程式碼範例定義上面的車像這樣的例子 複製代碼 代碼如下:var car = new Array();
car['colour'] = 'red';
car['wheels'] = 4;
car['hubcaps'] = 'spinning';
car['age'] = 4;

另一個可以使用簡略語句的地方是條件判斷語句: 複製代碼 代碼如下:var direction;
if(x < 200){
direction = 1;
} else {
direction = -1;
}

可以簡略為: 複製代碼 代碼如下:var direction = x < 200 ? 1 : -1;

JSON 資料格式
JSON 是 "JavaScript Object Notation" 的縮寫,由 Douglas Crockford 設計,JSON 改變了 JavaScript 在緩衝複雜資料格式方面的困境,如下例,假如你要描述一個樂隊,可以這樣寫: 複製代碼 代碼如下:var band = {
"name":"The Red Hot Chili Peppers",
"members":[
{
"name":"Anthony Kiedis",
"role":"lead vocals"
},
{
"name":"Michael 'Flea' Balzary",
"role":"bass guitar, trumpet, backing vocals"
},
{
"name":"Chad Smith",
"role":"drums,percussion"
},
{
"name":"John Frusciante",
"role":"Lead Guitar"
}
],
"year":"2009"
}

你可以在 JavaScript 中直接使用 JSON,甚至作為某些 API 的返回資料對象,以下代碼調用著名書籤網站 delicious.com 的一個 API,返回你在該網站的所有書籤,並顯示在你自己的網站: 複製代碼 代碼如下:<div id="delicious"></div><script>
function delicious(o){
var out = '<ul>';
for(var i=0;i<o.length;i++){
out += '<li><a href="' + o[i].u + '">' +
o[i].d + '</a></li>';
}
out += '</ul>';
document.getElementById('delicious').innerHTML = out;
}
</script>
<script src="http://feeds.delicious.com/v2/json/codepo8/javascript?count=15&callback=delicious"></script>

JavaScript 本地函數 (Math, Array 和 String)
JavaScript 有很多內建函數,有效使用,可以避免很多不必要的代碼,比如,從一個數組中找出最大值,傳統的方法是: 複製代碼 代碼如下:var numbers = [3,342,23,22,124];
var max = 0;
for(var i=0;i<numbers.length;i++){
if(numbers[i] > max){
max = numbers[i];
}
}
alert(max);

使用內建函數可以更容易實現: 複製代碼 代碼如下:var numbers = [3,342,23,22,124];
numbers.sort(function(a,b){return b - a});
alert(numbers[0]);

另一個方法是使用 Math.max() 方法: 複製代碼 代碼如下:Math.max(12,123,3,2,433,4); // returns 433

你可以用這個方法協助探測瀏覽器 複製代碼 代碼如下:var scrollTop= Math.max(
doc.documentElement.scrollTop,
doc.body.scrollTop
);

這解決了 IE 瀏覽器的一個問題,通過這種方法,你總是可以找到那個正確的值,因為瀏覽器不支援的那個值會返回 undefined。
還可以使用 JavaScript 內建的 split() 和 join() 函數處理 HTML 對象的 CSS 類名,如果 HTML 對象的類名是空格隔開的多個名字,你在為它追加或刪除一個 CSS 類名的時候需要特別注意,如果該對象還沒有類名屬性,可以直接將新的類名賦予它,如果已經存在類名,新增的類名前必須有一個空格,用傳統的 JavaScript 方法是這樣實現的: 複製代碼 代碼如下:function addclass(elm,newclass){
var c = elm.className;
elm.className = (c === '') ? newclass : c+' '+newclass;
}

使用 split 和 join 方法則直觀優雅得多: 複製代碼 代碼如下:function addclass(elm,newclass){
var classes = elm.className.split(' ');
classes.push(newclass);
elm.className = classes.join(' ');
}

事件代理
與其在 HTML 文檔中設計一堆事件,不如直接設計一個事件代理,舉例說明,假如你有一些連結,使用者點擊後不想開啟連結,而是執行某個事件,HTML 程式碼如下: 複製代碼 代碼如下:<h2>Great Web resources</h2>
<ul id="resources">
<li><a href="http://opera.com/wsc">Opera Web Standards Curriculum</a></li>
<li><a href="http://sitepoint.com">Sitepoint</a></li>
<li><a href="http://alistapart.com">A List Apart</a></li>
<li><a href="http://yuiblog.com">YUI Blog</a></li>
<li><a href="http://blameitonthevoices.com">Blame it on the voices</a></li>
<li><a href="http://oddlyspecific.com">Oddly specific</a></li>
</ul>

傳統的事件處理是遍曆各個連結,加上各自的事件處理: 複製代碼 代碼如下:// Classic event handling example
(function(){
var resources = document.getElementById('resources');
var links = resources.getElementsByTagName('a');
var all = links.length;
for(var i=0;i<all;i++){
// Attach a listener to each link
links[i].addEventListener('click',handler,false);
};
function handler(e){
var x = e.target; // Get the link that was clicked
alert(x);
e.preventDefault();
};
})();

使用事件代理,可以直接處理,無需遍曆: 複製代碼 代碼如下:(function(){
var resources = document.getElementById('resources');
resources.addEventListener('click',handler,false);
function handler(e){
var x = e.target; // get the link tha
if(x.nodeName.toLowerCase() === 'a'){
alert('Event delegation:' + x);
e.preventDefault();
}
};
})();

匿名函數與 Module 模式
JavaScript 的一個問題是,任何變數,函數或是對象,除非是在某個函數內部定義,否則,就是全域的,意味著同一網頁的別的代碼可以訪問並改寫這個變數(ECMA 的 JavaScript 5 已經改變了這一狀況 - 譯者),使用匿名函數,你可以繞過這一問題。
比如,你有這樣一段代碼,很顯然,變數 name, age, status 將成為全域變數 複製代碼 代碼如下:var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}

為了避免這一問題,你可以使用匿名函數: 複製代碼 代碼如下:var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
}();

如果這個函數不會被調用,可以更直接為: 複製代碼 代碼如下:(function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
})();

如果要訪問其中的對象或函數,可以: 複製代碼 代碼如下:var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
return{
createMember:function(){
// [...]
},
getMemberDetails:function(){
// [...]
}
}
}();
// myApplication.createMember() and
// myApplication.getMemberDetails() now works.

這就是所謂 Module 模式或單例模式(Singleton),該模式為 Douglas Crockford 所推崇,並被大量應用在 Yahoo User Interface Library YUI。
假如你想在別的地方調用裡面的方法,又不想在調用前使用 myApplication 這個對象名,可以在匿名函數中返回這些方法,甚至用簡稱返回: 複製代碼 代碼如下:var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
return{
create:createMember,
get:getMemberDetails
}
}();
//myApplication.get() and myApplication.create() now work.

代碼配置
別人使用你編寫的 JavaScript 代碼的時候,難免會更改某些代碼,但這會很困難,因為不是每個人都很容易讀懂別人的代碼,與其這樣,不如建立一個代碼設定物件,別人只需要在這個對象中更改某些配置即可實現代碼的更改。這裡有一篇 JavaScript 設定物件詳解的文章,簡單說:

· 在代碼中建立一個叫做 configuration 的對象

· 裡面儲存所有可以更改的配置,如 CSS ID 和類名,按鈕的標籤文字,描述性文字,本地化語言設定

· 將該對象設定為全域對象,以便別人直接存取並改寫

你應當在最後一步做這項工作,這裡有一個文章,交付代碼前的5件事值的參考。
同後台互動
JavaScript 是一門前台語言,你需要別的語言同後台互動,並返回資料,使用 AJAX,你可以讓 JavaScript 直接使用同背景互動,將複雜的資料處理交由幕後處理。
JavaScript 架構
自己編寫適應各種瀏覽器的代碼是完全浪費時間,應當選擇一個 JavaScript 架構,讓這些複雜的事情交給架構處理。
更多資源

· Douglas Crockford on JavaScript
JavaScript 深度視頻教程

· The Opera Web Standards Curriculum
JavaScript 詳解

延伸閱讀

· 有關 JavaScript 的 10 件讓人費解的事情

· 新 API 尋求讓 JavaScript 操作本地檔案

· 讓 JavaScript 拯救 HTML5 的離線儲存

· 開源項目越來越青睞 JavaScript

· Javascript 是一個錯誤嗎?

· Javascript 2 前途塵埃落定

· Google 排名中的 10 個最著名的 JavaScript 庫

· ECMA 推出 JavaScript 5

本文國際來源:Smashing Magazine Seven JavaScript Things I Wish I Knew Much Earlier In My Career (原文作者:Christian Heilmann)

【出自部落格園深藍居,轉載請註明作者出處】
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.