




已閱讀5頁,還剩3頁未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
一.摘要本文是jQuery系列教程的劇場版, 即和jQuery這條主線無關(guān), 主要介紹大家平時會忽略的一些javascript細(xì)節(jié). 適合希望鞏固javascript理論知識和基礎(chǔ)知識的開發(fā)人員閱讀.二.前言最近面試過一些人, 發(fā)現(xiàn)即使經(jīng)驗(yàn)豐富的開發(fā)人員, 對于一些基礎(chǔ)的理論和細(xì)節(jié)也常常會模糊. 寫本文是因?yàn)榫臀易约憾缘谝淮螌W(xué)習(xí)下面的內(nèi)容時發(fā)現(xiàn)自己確實(shí)有所收獲和感悟. 其實(shí)我們?nèi)菀缀鲆暤膉avascript的細(xì)節(jié)還有更多, 本文僅是冰山一角. 希望大家都能通過本文有所斬獲.三.Javascript面向?qū)ο驤avascript是一門面向?qū)ο蟮恼Z言, 雖然很多書上都有講解,但還是有很多初級開發(fā)者不了解. 創(chuàng)建對象ps: 以前寫過一篇詳細(xì)的創(chuàng)建對象的文章(原型方法, 工廠方法等)但是找不到了, 回頭如果還能找到我再添加進(jìn)來.下面僅僅簡單介紹.在C#里我們使用new關(guān)鍵字創(chuàng)建對象, 在javascript中也可以使用new關(guān)鍵字:var objectA = new Object();但是實(shí)際上new可以省略:var objectA = Object();但是我建議為了保持語法一直, 總是帶著new關(guān)鍵字聲明一個對象.創(chuàng)建屬性并賦值在javascript中屬性不需要聲明, 在賦值時即自動創(chuàng)建:objectA.name = my name;訪問屬性一般我們使用.來分層次的訪問對象的屬性:alert(objectA.name);嵌套屬性對象的屬性同樣可以是任何javascript對象:var objectB = objectA;objectB.other = objectA;/此時下面三個值相當(dāng), 并且改變其中任何一個值其余兩個值都改變objectA.name;objectB.name;objectB.;使用索引如果objectA上有一個屬性名稱為school.college, 那么我們沒法通過.訪問,因?yàn)閛bjectA.school.college語句是指尋找objectA的school屬性對象的college屬性.這種情況我們需要通過索引設(shè)置和訪問屬性: objectAschool.college = BITI; alert(objectAschool.college);下面幾個語句是等效的: objectAschool.college = BITI; var key = school.college alert(objectAschool.college); alert(objectAschool + . + college); alert(objectAkey);JSON 格式語法JSON是指Javascript Object Notation, 即Javascript對象表示法.我們可以用下面的語句聲明一個對象,同時創(chuàng)建屬性: /JSON var objectA = name: myName, age: 19, school: college: 大學(xué), high school: 高中 , like:睡覺,C#,還是睡覺 JSON的語法格式是使用和表示一個對象, 使用屬性名稱:值的格式來創(chuàng)建屬性, 多個屬性用,隔開.上例中school屬性又是一個對象. like屬性是一個數(shù)組. 使用JSON格式的字符串創(chuàng)建完對象后, 就可以用.或者索引的形式訪問屬性:objectA.schoolhigh school;objectA.like1;靜態(tài)方法與實(shí)例方法靜態(tài)方法是指不需要聲明類的實(shí)例就可以使用的方法.實(shí)例方法是指必須要先使用new關(guān)鍵字聲明一個類的實(shí)例, 然后才可以通過此實(shí)例訪問的方法. function staticClass() ; /聲明一個類 staticClass.staticMethod = function() alert(static method) ; /創(chuàng)建一個靜態(tài)方法 staticCtotype.instanceMethod = function() instance method ; /創(chuàng)建一個實(shí)例方法 上面首先聲明了一個類staticClass, 接著為其添加了一個靜態(tài)方法staticMethod 和一個動態(tài)方法instanceMethod. 區(qū)別就在于添加動態(tài)方法要使用prototype原型屬性.對于靜態(tài)方法可以直接調(diào)用:staticClass.staticMethod();但是動態(tài)方法不能直接調(diào)用:staticClass.instanceMethod(); /語句錯誤, 無法運(yùn)行.需要首先實(shí)例化后才能調(diào)用: var instance = new staticClass();/首先實(shí)例化 instance.instanceMethod(); /在實(shí)例上可以調(diào)用實(shí)例方法四.全局對象是window屬性通常我們在標(biāo)簽中聲明一個全局變量, 這個變量可以供當(dāng)前頁面的任何方法使用: var objectA = new Object(); 然而我們還應(yīng)該知道, 實(shí)際上全局變量objectA是創(chuàng)建在window對象上, 可以通過window對象訪問到:window.objectA五.函數(shù)究竟是什么我們都知道如何創(chuàng)建一個全局函數(shù)以及如何調(diào)用: function myMethod() alert(Hello!); myMethod(); 其實(shí)同全局對象一樣, 使用function關(guān)鍵字創(chuàng)建的方法(也可以創(chuàng)建類)的名稱, 實(shí)際上是為window對象創(chuàng)建了myMethod屬性, 并且值是一個匿名方法, 上面的語句等同于: window.myMethod = function() alert(Hello!); 無論使用哪種方式聲明, 實(shí)際保存時都是使用函數(shù)名創(chuàng)建window對象的屬性. 并且值只有函數(shù)體沒有函數(shù)名稱.所以,下面三種聲明方式是等效的: function myMethod() alert(Hello!); window.myMethod = function() alert(Hello!); myMethod = function() alert(Hello!); 六.this究竟是什么在C#中,this變量通常指類的當(dāng)前實(shí)例. 在javascript則不同, javascript中的this是函數(shù)上下文,不是由聲明決定,而是由如何調(diào)用決定.因?yàn)槿趾瘮?shù)其實(shí)就是window的屬性, 所以在頂層調(diào)用全局函數(shù)時的this是指window對象.下面的例子可以很好的說明這一切: var o1 = name: o1 name ; = window name; function showName() alert(); o1.show = showName; window.show = showName; showName(); o1.show(); window.show();結(jié)果:結(jié)果證明在頂層調(diào)用函數(shù)和使用window對象調(diào)用函數(shù)時, this都指向window對象. 而在對象中調(diào)用函數(shù)時this指向當(dāng)前對象.七.javascript中的閉包閉包的概念比較難以理解, 先看閉包的定義:閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達(dá)式(通常是一個函數(shù)),因而這些變量也是該表達(dá)式的一部分。簡單表達(dá):閉包就是function實(shí)例以及執(zhí)行function實(shí)例時來自環(huán)境的變量.先看下面的例子: function start() var count = 0; window.setInterval(function() document.getElementById(divResult).innerHTML += count + ; count+; , 3000); ; start(); count是start函數(shù)體內(nèi)的變量, 通常我們理解count的作用于是在start()函數(shù)內(nèi), 在調(diào)用start()函數(shù)結(jié)束后應(yīng)該也會消失.但是此示例的結(jié)果是count變量會一直存在,并且每次被加1:因?yàn)閏ount變量是setInterval中創(chuàng)建的匿名函數(shù)(就是包含count+的函數(shù))的閉包的一部分!再通俗的講, 閉包首先就是函數(shù)本身, 比如上面這個匿名函數(shù)本身, 同時加上在這個函數(shù)運(yùn)行時需要用
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 四年級美術(shù)下冊師資培訓(xùn)計劃
- 新北師大版三年級數(shù)學(xué)下冊錯題復(fù)習(xí)計劃
- 中學(xué)生健康體育鍛煉一小時計劃
- 金蝶KIS專業(yè)版客戶應(yīng)收賬款流程他
- 二年級數(shù)學(xué)下冊教學(xué)評價計劃
- 語文教師師徒結(jié)對網(wǎng)絡(luò)學(xué)習(xí)計劃
- 幼兒園消防安全教育課程計劃
- 六年級上冊英語培優(yōu)輔差口語提升計劃
- xx煤礦智能化建設(shè)智能維護(hù)計劃
- 六年級勞動與技術(shù)實(shí)驗(yàn)計劃
- 職業(yè)行為習(xí)慣課件
- 2024年深圳市中考生物試卷真題(含答案解析)
- 新疆維吾爾自治區(qū)2024年普通高校招生單列類(選考外語)本科二批次投檔情況 (理工)
- 綠化養(yǎng)護(hù)服務(wù)投標(biāo)方案(技術(shù)標(biāo))
- DB4451-T 1-2021《地理標(biāo)志產(chǎn)品+鳳凰單叢(樅)茶》-(高清現(xiàn)行)
- 消防管理檢查評分表
- 無人機(jī)駕駛員證照考試培訓(xùn)題庫與答案
- JJG 1149-2022 電動汽車非車載充電機(jī)(試行)
- 2022年(詳細(xì)版)高中數(shù)學(xué)學(xué)業(yè)水平考試知識點(diǎn)
- 播音主持重音的教學(xué)課件
- 蛋糕制作工藝課件(PPT81張)
評論
0/150
提交評論