一些相見恨晚的 JavaScript 技巧
簡略語句
JavaScript 可以使用簡略語句快速創(chuàng)建對象和數(shù)組,比如下面的代碼:
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 就此創(chuàng)建,不過需要特別注意,結(jié)束花括號前一定不要加 ";" 否則在 IE 會遇到很大麻煩。
創(chuàng)建數(shù)組的傳統(tǒng)方法是:
var moviesThatNeedBetterWriters = new Array(
'Transformers','Transformers2','Avatar','Indiana Jones 4'
);
使用簡略語句則:
var moviesThatNeedBetterWriters = [
'Transformers','Transformers2','Avatar','Indiana Jones 4'
];
關(guān)于數(shù)組的另一個問題是有沒有一個關(guān)聯(lián)數(shù)組這樣的東西。你會發(fā)現(xiàn)很多的代碼示例定義上面的車像這樣的例子
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;
}
可以簡略為:
JSON 數(shù)據(jù)格式
JSON 是 "JavaScript Object Notation" 的縮寫,由 Douglas Crockford 設(shè)計,JSON 改變了 JavaScript 在緩存復雜數(shù)據(jù)格式方面的困境,如下例,假如你要描述一個樂隊,可以這樣寫:
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 的返回數(shù)據(jù)對象,以下代碼調(diào)用著名書簽網(wǎng)站 delicious.com 的一個 API,返回你在該網(wǎng)站的所有書簽,并顯示在你自己的網(wǎng)站:
<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 本地函數(shù) (Math, Array 和 String)
JavaScript 有很多內(nèi)置函數(shù),有效的使用,可以避免很多不必要的代碼,比如,從一個數(shù)組中找出最大值,傳統(tǒng)的方法是:
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);
使用內(nèi)置函數(shù)可以更容易實現(xiàn):
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 內(nèi)置的 split() 和 join() 函數(shù)處理 HTML 對象的 CSS 類名,如果 HTML 對象的類名是空格隔開的多個名字,你在為它追加或刪除一個 CSS 類名的時候需要特別注意,如果該對象還沒有類名屬性,可以直接將新的類名賦予它,如果已經(jīng)存在類名,新增的類名前必須有一個空格,用傳統(tǒng)的 JavaScript 方法是這樣實現(xiàn)的:
function addclass(elm,newclass){
var c = elm.className;
elm.className = (c === '') ? newclass : c+' '+newclass;
}
使用 split 和 join 方法則直觀優(yōu)雅得多:
function addclass(elm,newclass){
var classes = elm.className.split(' ');
classes.push(newclass);
elm.className = classes.join(' ');
}
事件代理
與其在 HTML 文檔中設(shè)計一堆事件,不如直接設(shè)計一個事件代理,舉例說明,假如你有一些鏈接,用戶點擊后不想打開鏈接,而是執(zhí)行某個事件,HTML 代碼如下:
<h2>Great Web resources</h2>
<ul id="resources">
<li><a >Opera Web Standards Curriculum</a></li>
<li><a >Sitepoint</a></li>
<li><a >A List Apart</a></li>
<li><a >YUI Blog</a></li>
<li><a >Blame it on the voices</a></li>
<li><a >Oddly specific</a></li>
</ul>
傳統(tǒng)的事件處理是遍歷各個鏈接,加上各自的事件處理:
// 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();
}
};
})();
匿名函數(shù)與 Module 模式
JavaScript 的一個問題是,任何變量,函數(shù)或是對象,除非是在某個函數(shù)內(nèi)部定義,否則,就是全局的,意味著同一網(wǎng)頁的別的代碼可以訪問并改寫這個變量(ECMA 的 JavaScript 5 已經(jīng)改變了這一狀況 - 譯者),使用匿名函數(shù),你可以繞過這一問題。
比如,你有這樣一段代碼,很顯然,變量 name, age, status 將成為全局變量
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
為了避免這一問題,你可以使用匿名函數(shù):
var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
}();
如果這個函數(shù)不會被調(diào)用,可以更直接為:
(function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
})();
如果要訪問其中的對象或函數(shù),可以:
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。
假如你想在別的地方調(diào)用里面的方法,又不想在調(diào)用前使用 myApplication 這個對象名,可以在匿名函數(shù)中返回這些方法,甚至用簡稱返回:
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 代碼的時候,難免會更改某些代碼,但這會很困難,因為不是每個人都很容易讀懂別人的代碼,與其這樣,不如創(chuàng)建一個代碼配置對象,別人只需要在這個對象中更改某些配置即可實現(xiàn)代碼的更改。這里有一篇 JavaScript 配置對象詳解的文章,簡單說:
· 在代碼中創(chuàng)建一個叫做 configuration 的對象
· 里面保存所有可以更改的配置,如 CSS ID 和類名,按鈕的標簽文字,描述性文字,本地化語言設(shè)置
· 將該對象設(shè)置為全局對象,以便別人直接訪問并改寫
你應當在最后一步做這項工作,這里有一個文章,交付代碼前的5件事值的參考。
同后臺交互
JavaScript 是一門前臺語言,你需要別的語言同后臺交互,并返回數(shù)據(jù),使用 AJAX,你可以讓 JavaScript 直接使用同后臺的交互,將復雜的數(shù)據(jù)處理交由后臺處理。
JavaScript 框架
自己編寫適應各種瀏覽器的代碼是完全浪費時間,應當選擇一個 JavaScript 框架,讓這些復雜的事情交給框架處理。
更多資源
· Douglas Crockford on JavaScript
JavaScript 深度視頻教程
· The Opera Web Standards Curriculum
JavaScript 詳解
延伸閱讀
· 有關(guān) JavaScript 的 10 件讓人費解的事情
· Google 排名中的 10 個最著名的 JavaScript 庫
本文國際來源:Smashing Magazine Seven JavaScript Things I Wish I Knew Much Earlier In My Career (原文作者:Christian Heilmann)
相關(guān)文章
JavaScript實現(xiàn)獲取設(shè)備網(wǎng)絡連接信息
作為前端開發(fā),做好用戶體驗是很重要的,日常開發(fā)中我們經(jīng)??梢杂龅接脩艟W(wǎng)速慢導致靜態(tài)資源加載慢,從而給影響用戶體驗,所以本文來和大家分享一個有趣的API,可以實現(xiàn)獲取網(wǎng)絡信息2023-05-05JavaScript中的console.time()函數(shù)詳細介紹
這篇文章主要介紹了JavaScript中的console.time()函數(shù)詳細介紹,console.time()函數(shù)主要用來統(tǒng)計程序執(zhí)行時間,需要的朋友可以參考下2014-12-12JS實現(xiàn)select選中option觸發(fā)事件操作示例
這篇文章主要介紹了JS實現(xiàn)select選中option觸發(fā)事件操作,結(jié)合實例形式總結(jié)分析了javascript針對select下拉選中option項觸發(fā)事件相關(guān)操作技巧,需要的朋友可以參考下2018-07-07代碼塊高亮可復制顯示js插件highlight.js+clipboard.js整合
最近有個需求是將jsp頁面上的某一段代碼塊格式化成類似CSDN的代碼塊的樣式,而且很多平臺都使用了這樣的功能,下面就為大家簡單分享一下2021-02-02JS簡單實現(xiàn)滑動加載數(shù)據(jù)的方法示例
這篇文章主要介紹了JS簡單實現(xiàn)滑動加載數(shù)據(jù)的方法,涉及javascript事件響應及頁面元素屬性動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-10-10全面解析Bootstrap中scrollspy(滾動監(jiān)聽)的使用方法
這篇文章主要為大家全面解析Bootstrap中scrollspy(滾動偵聽)的使用方法,感興趣的小伙伴們可以參考一下2016-06-06檢測是否已安裝 .NET Framework 3.5的js腳本
管理員必須首先確認存在 .NET Framework 3.5 運行庫,然后才能將 Windows Presentation Foundation (WPF) 應用程序部署在面向 .NET Framework 3.5 的系統(tǒng)上。2009-02-02