日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JavaScript实用技巧(一)

發(fā)布時(shí)間:2023/12/31 javascript 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript实用技巧(一) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
JavaScript 的成功讓人津津樂道,為 Web 網(wǎng)頁編寫 JavaScript 代碼已經(jīng)是所有 Web 設(shè)計(jì)師的基本功,這門有趣的語言蘊(yùn)藏著許多不為人熟知的東西,即使多年的 JavaScript 程序員,也未能完全吃透。本文從7個(gè)方面講述 JavaScript 中那些你不很熟知但非常實(shí)用的技巧。

簡略語句
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 會(huì)遇到很大麻煩。

創(chuàng)建數(shù)組的傳統(tǒng)方法是:

var?arrayTest?=?new?Array(
????
'test1','test2','test3','test4'
);

?

使用簡略語句則:

var?arrayTest?=?['test1','test2','test3','test4'];

?

?

另一個(gè)可以使用簡略語句的地方是條件判斷語句:

var?direction;
if(x?<?200){
???direction?
=?1;
}
else{
???direction?
=?-1;
}

//可以簡略為:
var?direction?=?x?<?200???1?:?-1;

?


JSON 數(shù)據(jù)格式
JSON 是 "JavaScript Object Notation" 的縮寫,由 Douglas Crockford 設(shè)計(jì),JSON 改變了 JavaScript 在緩存復(fù)雜數(shù)據(jù)格式方面的困境,如下例,假如你要描述一個(gè)樂隊(duì),可以這樣寫:


var?band?=?{
???
"name":"My?name?is?test1",
???
"Members":[
?????????????{
"name":"name1","role":"role1"},
?????????????{
"name":"name2","role":"role2"},
?????????????{
"name":"name3","role":"role3"},
?????????????{
"name":"name4","role":"role4"}
?????????????],
???
"year":"2010"
}

?

?

你可以在 JavaScript 中直接使用 JSON,甚至作為某些 API 的返回?cái)?shù)據(jù)對象,以下代碼調(diào)用著名書簽網(wǎng)站 delicious.com 的一個(gè) 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ù),有效的使用,可以避免很多不必要的代碼,比如,從一個(gè)數(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ù)可以更容易實(shí)現(xiàn):

var?numbers?=?[3,342,23,22,124];
numbers.sort(
function(a,b){return?b?-?a});
alert(numbers[
0]);

?

?

另一個(gè)方法是使用 Math.max() 方法:

Math.max(12,123,2,3,422,4);//return?422

?

?

你可以用這個(gè)方法幫助探測瀏覽器

var?scrollTop?=?Math.max(doc.documentElement.scrollTop,doc.body.scrollTop);

?

這解決了 IE 瀏覽器的一個(gè)問題,通過這種方法,你總是可以找到那個(gè)正確的值,因?yàn)闉g覽器不支持的那個(gè)值會(huì)返回 undefined。

還可以使用 JavaScript 內(nèi)置的 split() 和 join() 函數(shù)處理 HTML 對象的 CSS 類名,如果 HTML 對象的類名是空格隔開的多個(gè)名字,你在為它追加或刪除一個(gè) CSS 類名的時(shí)候需要特別注意,如果該對象還沒有類名屬性,可以直接將新的類名賦予它,如果已經(jīng)存在類名,新增的類名前必須有一個(gè)空格,用傳統(tǒng)的 JavaScript 方法是這樣實(shí)現(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è)計(jì)一堆事件,不如直接設(shè)計(jì)一個(gè)事件代理,舉例說明,假如你有一些鏈接,用戶點(diǎn)擊后不想打開鏈接,而是執(zhí)行某個(gè)事件,HTML 代碼如下:



傳統(tǒng)的事件處理是遍歷各個(gè)鏈接,加上各自的事件處理:



使用事件代理,可以直接處理,無需遍歷:


匿名函數(shù)與 Module 模式
JavaScript 的一個(gè)問題是,任何變量,函數(shù)或是對象,除非是在某個(gè)函數(shù)內(nèi)部定義,否則,就是全局的,意味著同一網(wǎng)頁的別的代碼可以訪問并改寫這個(gè)變量(ECMA 的 JavaScript 5 已經(jīng)改變了這一狀況 - 譯者),使用匿名函數(shù),你可以繞過這一問題。

比如,你有這樣一段代碼,很顯然,變量 name, age, status 將成為全局變量



為了避免這一問題,你可以使用匿名函數(shù):



如果這個(gè)函數(shù)不會(huì)被調(diào)用,可以更直接為:



如果要訪問其中的對象或函數(shù),可以:



這就是所謂 Module 模式或單例模式(Singleton),該模式為 Douglas Crockford 所推崇,并被大量應(yīng)用在 Yahoo User Interface Library YUI。

假如你想在別的地方調(diào)用里面的方法,又不想在調(diào)用前使用 myApplication 這個(gè)對象名,可以在匿名函數(shù)中返回這些方法,甚至用簡稱返回:


代碼配置
別人使用你編寫的 JavaScript 代碼的時(shí)候,難免會(huì)更改某些代碼,但這會(huì)很困難,因?yàn)椴皇敲總€(gè)人都很容易讀懂別人的代碼,與其這樣,不如創(chuàng)建一個(gè)代碼配置對象,別人只需要在這個(gè)對象中更改某些配置即可實(shí)現(xiàn)代碼的更改。這里有一篇 JavaScript 配置對象詳解的文章,簡單說:

  • 在代碼中創(chuàng)建一個(gè)叫做 configuration 的對象
  • 里面保存所有可以更改的配置,如 CSS ID 和類名,按鈕的標(biāo)簽文字,描述性文字,本地化語言設(shè)置
  • 將該對象設(shè)置為全局對象,以便別人直接訪問并改寫

你應(yīng)當(dāng)在最后一步做這項(xiàng)工作,這里有一個(gè)文章,交付代碼前的5件事值的參考。
同后臺交互
JavaScript 是一門前臺語言,你需要?jiǎng)e的語言同后臺交互,并返回?cái)?shù)據(jù),使用 AJAX,你可以讓 JavaScript 直接使用同后臺的交互,將復(fù)雜的數(shù)據(jù)處理交由后臺處理。
JavaScript 框架
自己編寫適應(yīng)各種瀏覽器的代碼是完全浪費(fèi)時(shí)間,應(yīng)當(dāng)選擇一個(gè) JavaScript 框架,讓這些復(fù)雜的事情交給框架處理。
更多資源
  • Douglas Crockford on JavaScript
    JavaScript 深度視頻教程
  • The Opera Web Standards Curriculum
    JavaScript 詳解
延伸閱讀
  • 有關(guān) JavaScript 的 10 件讓人費(fèi)解的事情
  • 新 API 尋求讓 JavaScript 操作本地文件
  • 讓 JavaScript 拯救 HTML5 的離線存儲
  • 開源項(xiàng)目越來越青睞 JavaScript
  • Javascript 是一個(gè)錯(cuò)誤嗎?
  • Javascript 2 前途塵埃落定
  • Google 排名中的 10 個(gè)最著名的 JavaScript 庫
  • ECMA 推出 JavaScript 5

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

轉(zhuǎn)載于:https://www.cnblogs.com/xiaopin/archive/2010/08/16/1800607.html

總結(jié)

以上是生活随笔為你收集整理的JavaScript实用技巧(一)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 搞逼综合网 | 爱福利视频一区 | 韩国av网| 国模精品视频一区二区 | av全黄| 国内自拍偷拍视频 | 婷婷综合在线 | www黄色网址 | 久久成年 | 青青青青青青草 | 亚洲精品一级二级 | 手机免费看av | 日本在线高清 | 99这里| 大号bbwassbigav女 | 超碰中文字幕 | 337p日本大胆噜噜噜鲁 | 日韩成人综合网 | 亚洲黄色av | 东京久久 | 中文字幕一区二区三区人妻电影 | 日本内谢少妇xxxxx少交 | 久久视频在线观看免费 | 激情欧美一区二区免费视频 | 色综合av综合无码综合网站 | 欧美三级日本三级 | 免费播放片大片 | 亚洲国产综合av | 亚洲国产精品狼友在线观看 | 国产福利在线看 | 亚洲欧美日韩国产一区二区 | 老司机午夜剧场 | 亚洲视频一二区 | 中文字幕av久久爽一区 | 韩国三级与黑人 | 狠狠人妻久久久久久综合 | 四虎影视精品 | 成人欧美一区二区三区黑人动态图 | 97国产成人无码精品久久久 | www精品| 女同调教视频 | 麻豆视频免费版 | 神马久久久久久 | 亚洲第1页 | www.操操操 | 96精品国产 | 成人久久国产 | 欧美婷婷六月丁香综合色 | 亚洲精品成人片在线观看精品字幕 | 涩涩的视频在线观看 | 黄色国产在线 | 天天躁日日躁狠狠躁av麻豆男男 | 欧美国产精品一区二区 | 中文精品在线 | 麻豆视频免费入口 | 老司机av福利 | 日本精品免费视频 | 日韩影院一区二区 | 亚洲精品高清在线观看 | 狠狠操人人干 | 嫩草影院在线免费观看 | 婷婷久久亚洲 | 色网站入口 | 亚洲成人91 | 亚洲夜色| 黄色小视频免费网站 | 亚洲欧美日韩动漫 | av黄| 国产一区二区三区四区三区四 | 亚洲视频在线免费观看 | 欧美亚洲黄色片 | 国产精品一区二区精品 | 欧美人妻精品一区二区三区 | 污网站免费在线 | 欧美天天搞 | 青青青草视频 | 欧美乱妇狂野欧美在线视频 | 日本不卡一区二区在线观看 | 午夜视频一区二区三区 | 推特裸体gay猛交gay | 肉色丝袜小早川怜子av | 国产精品久久久久久久久久 | 99视频国产精品免费观看a | 女人特黄大aaaaaa大片 | 视频在线观看免费大片 | jizzjizz国产| 成年人黄色录像 | 国产精品一区二区三 | 一区二区三区四区人妻 | 欧美日韩一区二区三区在线电影 | 天天色成人 | 一本色道久久综合亚洲精品小说 | 日韩视频免费在线播放 | 另类小说婷婷 | www.av成人 | 国产精品美女久久久久久 | 日本一区二区在线视频 | 老女人黄色片 | 亚洲欧洲在线播放 |