JavaScript筆記_第1頁
JavaScript筆記_第2頁
JavaScript筆記_第3頁
JavaScript筆記_第4頁
JavaScript筆記_第5頁
已閱讀5頁,還剩3頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、1997年,ECMA出臺標(biāo)準(zhǔn)ECMA-262,次年ISO采用ECMAScript作為標(biāo)準(zhǔn)(ISO/IEC-16262).一個完整的JavaScript實現(xiàn)包括了:核心(ECMAScript)文檔對象模型(DOM)瀏覽器對象模型(BOM)ECMA-262/規(guī)定了:語法類型語句關(guān)鍵字保留字操作符對象ECMA-262支持Unicode·標(biāo)準(zhǔn),從而可以多語言開發(fā)。什么是ECMAScript兼容ECMA-262給出了ECMAScript兼容的定義。要想成為ECMAScript的實現(xiàn),則該實現(xiàn)必須做到: 支持ECMA-262描述的所有“類型、值、對象、屬性、函數(shù)以及程序句法和語義”(ECMA-2

2、62第1頁) 支持Unicode字符擴(kuò)展此外,兼容的實現(xiàn)還可以進(jìn)行下列擴(kuò)展。 添加ECMA-262沒有描述的“更多類型、值、對象、屬性和函數(shù)”。ECMA-262所說的這些新增特性,主要是指該標(biāo)準(zhǔn)中沒有規(guī)定的新對象和對象的新屬性。支持ECMA-262沒有定義的“程序和正則表達(dá)式語法”(也就是說,可以修改和擴(kuò)展內(nèi)置的正則表達(dá)式語法).第二章 在HTML中使用JavaScript1. <script>元素1). 有6個屬性值:1. async:可選。表示應(yīng)該立即下載腳本,但不應(yīng)該妨礙頁面中的其他操作,比如下載其他資源或者等待加載其他腳本。只對外部文件有效。2. charset:可選。表示

3、通過src屬性指定的代碼的字符集。由于大多數(shù)瀏覽器會忽略它的值,因此這個屬性很少有人用。3. defer:可選。表示腳本可以延遲到文檔完全被解析和顯示之后再執(zhí)行。只對外部腳本文件有效。IE7及更早版本對嵌入腳本也支持這個屬性4. language:已廢棄。原來用于表示編寫代碼使用的腳本語言(如JavaScript,JavaScript1.2或VBScript)。大多數(shù)瀏覽器會忽略這個屬性,因此沒有必要再用了。5. src:可選。表示包含要執(zhí)行代碼的外部文件。6. type:可選??梢钥闯墒莑anguage的替代屬性;表示編寫代碼使用的腳本語言的內(nèi)容類型(也稱為MIME類型)。雖然text/ja

4、vascript和text/ecmascript都已經(jīng)不被推薦使用,但人們一直使用的都還是text/javascript。實際上,服務(wù)器在傳送JavaScript文件時使用的MIME類型通常是application/x-javascript,但在type中設(shè)置這個值卻可能導(dǎo)致腳本被忽略。另外,在非IE瀏覽器中還可以使用以下值:application/javascript和application/ecmascript??紤]到約定俗成和最大限度的瀏覽器兼容性,目前type屬性的值依舊還是text/javascript。不過,這個屬性并不是必需的,如果沒有指定這個屬性,則其默認(rèn)自仍為text/jav

5、ascript。使用<script>元素的方式有兩種:直接在頁面中嵌入JavaScript代碼和包含外部JavaScript文件。在使用<script>嵌入JavaScript代碼時,記住不要在代碼中的任何地方出現(xiàn)“</script>”字符串。如果要使用”</script>”,則應(yīng)該這樣使用:”</script>”(轉(zhuǎn)義字符)將<script>放在<body>標(biāo)簽的最后,在解析包含的JavaScript代碼之前,頁面的內(nèi)容將完全呈現(xiàn)在瀏覽器中。而用戶也會因為瀏覽器窗口顯示空白頁面的時間縮短而感到打開頁面的速度加

6、快了。 defer屬性:立即下載,但延遲執(zhí)行,只用于外部js文件 defer=”defer”HTMl 4.01為<script>標(biāo)簽定義了defer屬性。這個屬性的用途是表明腳本在執(zhí)行時不會影響頁面的構(gòu)造。也就是說,腳本會被延遲到整個頁面都解析完畢后再運行。async屬性:立即下載,延遲執(zhí)行,但不保證順序。<noscript>元素:用于在不支持JavaScript的瀏覽器中顯示替代的內(nèi)容。這個元素可以包含能夠穿線在文檔<body>中的任何html元素(<script>元素除外)。1).瀏覽器不支持腳本2).瀏覽器支持腳本,但是被禁用這兩種情況才會

7、呈現(xiàn)<noscript>的內(nèi)容。第三章 基本概念嚴(yán)格模式下,不可以在局部作用域中定義全局變量第五章 引用類型5.1 Object類型1. 引用類型:引用類型是一種數(shù)據(jù)結(jié)構(gòu),用于將數(shù)據(jù)和功能組織在一起。它也常被稱為類,但這種稱呼并不妥當(dāng)。盡管ECMAScript從技術(shù)上講是一門面向?qū)ο蟮恼Z言,但它不具備傳統(tǒng)的面向?qū)ο笳Z言所支持的類和接口等基本結(jié)構(gòu)。引用類型有時候也被稱為對象定義,因為它們描述的是一類對象所具有的屬性和方法。2. 創(chuàng)建Object實例有三種方式1). var person = new Object(); = “NIcholas”; person.

8、age = 29;2). var person = name : “Nicholas”, age : 293). var person = ;/不推薦使用這種方式 =”Nicholas”; person.age = 29;3. 在通過對象字面量定義對象時,不會調(diào)用Object構(gòu)造函數(shù)。4. 一般來說,訪問對象屬性時使用的都是點表示法,這也是很多面向?qū)ο笳Z言中通用的語法。不過,在JavaScript中也可以使用方括號表示法來訪問對象的屬性。在使用方括號語法時,應(yīng)該將要訪問的屬性以字符串的形式放在方括號中,如:alert(person“name”);另外,以方括號表示法訪問對

9、象的屬性時,屬性名稱可以是變量,而點表示法不能是變量。如果屬性名字中包含會導(dǎo)致語法錯誤的字符,或者屬性名使用的是關(guān)鍵字和保留字,也可以使用方括號表示法。5.2 Array類型1. ECMAScript數(shù)組的每一項可以保存任何類型的數(shù)據(jù)。2. 創(chuàng)建數(shù)組的方式有兩種:1). var colors = new Array();var colors = new Array(20);/創(chuàng)建長度為20的數(shù)組var colors = new Array(“color”,9,8);/創(chuàng)建長度為3的數(shù)組,數(shù)組為“color”,8,92). var color =“”,”,”;/創(chuàng)建長度為3的數(shù)組 var col

10、or =,;/可能創(chuàng)建長度為5也可能為6的數(shù)組3. 數(shù)組的項數(shù)保存在其length屬性中,這個屬性始終會返回0或更大的值。且會實時更新4. 檢測數(shù)組1). 對于一個全局作用域而言,使用instanceof操作符就能得到滿意的結(jié)果。2). ECMAScript5新增了Array.isArray()方法。這個方法的目的是最終確定某個值到底是不是數(shù)組,而不管它是在哪個全局執(zhí)行環(huán)境中創(chuàng)建的。5. 轉(zhuǎn)換方法1). toString(),toLocaleString(),valueOf()調(diào)用toString()方法會返回由數(shù)組中每個值的字符串形式拼接而成的一個以逗號分隔的字符串。valueOf()返回的

11、還是數(shù)組。調(diào)用數(shù)組的toLocaleString()方法會調(diào)用數(shù)組中項的toLocaleString()方法2). 棧方法:push(),pop()push()可以接受任意數(shù)量的參數(shù),把他們逐個添加到數(shù)組末尾pop()從數(shù)組末尾一出最后一項3). 隊列方法 shift(),unshift()shit()移除數(shù)組中的第一個項并返回該項unshift()在數(shù)組前端添加任意個項,并返回新數(shù)組的長度。6. 重排序方法1). reverse()方法使數(shù)組倒序2). sort()1. 在默認(rèn)情況下,sort()方法按升序排列數(shù)組即最小的值排在最后面,為了實現(xiàn)排序,sort()方法會調(diào)用每個數(shù)組項的toSt

12、ring()方法,然后比較得到的字符串來確定如何排序。2. sort()方法可以接受一個比較函數(shù),以便于我們指定哪一個值位于哪一個的前面function compare(a,b)if(a<b)return 1;else if(a>b)return -1;var values = 0,1,5,10,15;values.sort(compare);alert(values);/15,10,5,1,07. 操作方法1). concat() 基于當(dāng)前數(shù)組中的所有項,創(chuàng)建一個新數(shù)組。這個方法會先創(chuàng)建當(dāng)前數(shù)組的一個副本,然后將接收到的參數(shù)添加到這個副本的末尾,最后返回新構(gòu)建的數(shù)組。在沒有個co

13、ncat()方法傳遞參數(shù)的情況下,它只是復(fù)制當(dāng)前數(shù)組并返回副本。如果傳遞給concat()方法的是一個或者多個數(shù)組,則該方法會將這些數(shù)組中的每一項都添加到結(jié)果數(shù)組中。如果傳遞的不是數(shù)組。這些值就會被簡單的添加到結(jié)果數(shù)組的末尾。2). slice() 基于當(dāng)前數(shù)組中的一個或者多個項創(chuàng)建新數(shù)組slice()可以接受一個或兩個參數(shù)。只有一個參數(shù)時,返回參數(shù)指定位置開始到當(dāng)前數(shù)組末尾的所有項。如果有兩個參數(shù),該方法返回起始和結(jié)束位置之間的項,但不包括結(jié)束位置的項。3). splice() 多種用法刪除: 可以刪除任意數(shù)量的項,只需指定2個參數(shù):要刪除的第一項的位置和要刪除的項數(shù)。插入: 可以向指定的位

14、置插入任意數(shù)量的項,只需提供3個參數(shù):起始位置、0(要刪除的項數(shù))和要插入的項數(shù)。如果要插入多個項,可以再傳入第四、五以至任意多個項替換: 可以向指定位置插入任意數(shù)量的項,且同時刪除任意數(shù)量的項,只需指定3個參數(shù):起始位置、要插入的項數(shù)和要插入的任意數(shù)量的項。插入的項數(shù)不必與刪除的項數(shù)相等。8. 位置方法1). indexof() lastIndexOf()這兩個方法都接受兩個參數(shù): 要查找的項和(可選的)表示查找起點位置的索引。indexOf()從數(shù)組的開頭開始向后查找lastIndexOf()從數(shù)組的末尾開始向前查找9. 迭代方法ECMAScript為數(shù)組定義了5個迭代方法。每個方法都接收

15、兩個參數(shù):要在每一項上運行的函數(shù)和(可選的)運行該函數(shù)的作用域?qū)ο笥绊憈his的值。傳入這些方法中的函數(shù)會接受三個參數(shù):數(shù)組項的值,該項在數(shù)組中的位置和數(shù)組對象本身。1). every()對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對每一項都返回true則返回true2). filter()對數(shù)組中的每一項運行給定函數(shù),返回該函數(shù)會返回true的項組成的數(shù)組3). forEach()對數(shù)組中的每一項運行給定函數(shù),這個方法沒有返回值4). map()對數(shù)組中的每一項運行給定函數(shù),返回每次函數(shù)調(diào)用結(jié)果組成的數(shù)組5). some()對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對任一項返回true則返回tru

16、e10. 歸并方法1). reduce()接受兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和(可選的)作為歸并基礎(chǔ)的初始值傳給reduce()的函數(shù)接收4個參數(shù):前一個值、當(dāng)前值、項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。從數(shù)組的第一項開始,逐個遍歷到最后。2). reduceRight();接受兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和(可選的)作為歸并基礎(chǔ)的初始值傳給reduce()的函數(shù)接收4個參數(shù):前一個值、當(dāng)前值、項的索引和數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。從數(shù)組的最后一項開始,逐個遍歷到第一項。5.3 Date類型1. Date類型使用

17、自UTC(Coordinated Universal Time 國際協(xié)調(diào)時間)1970年1月1日午夜(零時)開始經(jīng)過的毫秒數(shù)來保存日期。在使用這種數(shù)據(jù)存儲格式的條件下,Date類型保存的日期能夠精確到1970年1月1日之前或之后的285616年2. 創(chuàng)建一個日期對象,使用new操作符和Date構(gòu)造函數(shù)即可,var now = new Date();在不傳遞參數(shù)的情況下,自動獲得當(dāng)前日期和時間。如果想根據(jù)特定的日期和時間創(chuàng)建日期對象,必須傳入該日期的毫秒數(shù)。3. Date.parse()返回表示日期的毫秒數(shù) Date.UTC()返回表示日期的毫秒數(shù)日期的格式:(Date.parse())1).

18、“月/日/年”,如”6/13/2015”2). “英文月名,日,年”,如“January 15, 2016”3). “英文星期幾 英文月名 日 年 時:分:秒”,如”Tue May 25 2015 00:00:00 GMT-0700”4). ISO 8601擴(kuò)展格式 YYYY-MM-DDTHH:mm:ss.ssZ,例如(2015-05-25T00:00:00),只有兼容ECMAScript5的實現(xiàn)支持這種格式。5). “年/月/日”,”日/月/年“也可以。例如:Date.parse(“May 25,2015”);Date.UTC()的參數(shù)分別是年份,基于0的月份(0表示1月),月中的哪一天(1

19、到31)小時數(shù)(023),分鐘,秒以及毫秒數(shù)。只有前兩個參數(shù)是必須的。例如:Date.UTC(2015,3,25,15,00,00);4.now()返回表示調(diào)用這個方法時的日期和時間的毫秒數(shù)。toString()返回帶有時區(qū)信息的日期和時間toLocaleString()返回與瀏覽器設(shè)置的地區(qū)相適應(yīng)的格式的時間toDateString()以特定于實現(xiàn)的格式顯示星期幾、月、日和年toTimeString()以特定于實現(xiàn)的格式顯示時、分、秒和時區(qū)toLocaleDateString()以特定于地區(qū)的格式顯示星期幾、月、日和年toLocaleTimeString()以特定于地區(qū)的格式顯示時、分、秒和

20、時區(qū)toUTCString()以特定于實現(xiàn)的格式完整的UTC日期getTime()返回表示日期的毫秒數(shù)setTime()以毫秒數(shù)設(shè)置日期getFullYear()取得4位數(shù)的年份(2007而不是07)getUTCFullYear()返回UTC日期的4位數(shù)年份setFullYear(年)設(shè)置日期的年份(傳入4位數(shù))setUTCFullYear(年)設(shè)置UTC日期的年份getMonth()返回日期中的月份getUTCMonth()返回UTC日期的月份setMonth(月)設(shè)置日期中的月份,(0表示1月,超過11自動增加年份)setUTCMonth(月)設(shè)置日期中的月份,(0表示1月,超過11自動增

21、加年份)getDate()返回日期中的天數(shù)(1到31)getUTCDate()返回UTC日期中的天數(shù)setDate(日)設(shè)置日期中的天數(shù)(如果超過該月份應(yīng)有的日期就增加月份)setUTCDate(日)設(shè)置UTC日期中的天數(shù)(如果超過月份應(yīng)有的日期就增加月份)getDay()返回日期中星期的星期幾(不可設(shè)置)getUTCDay()返回UTC日期中星期的星期幾(不可設(shè)置)getHours()返回日期中的小時數(shù)(023)getUTCHours()返回UTC日期中的小時數(shù)(023)setHours(時)設(shè)置日期中的小時數(shù)(超過23則增加天數(shù))setUTCHours(時)設(shè)置UTC日期中的小時數(shù)(超過23則增加天數(shù))getMinutes()返回日期中的分鐘數(shù)getUTCMinutes()返回UTC日期中的分鐘數(shù)setMinutes(分)設(shè)置日期中的分鐘數(shù)(如果超過了59,就會增加時鐘數(shù))setUTCMinutes(分)設(shè)置UTC日期中的分鐘數(shù)(如果超過了59,就會增加時鐘數(shù))getSeconds()返回日期中的秒數(shù)getUTCSeconds()返回UTC日期中的秒數(shù)setSeconds(秒)設(shè)置日期中的秒數(shù)(如果超過了59,就會增加分鐘數(shù))setUTCSeconds(秒)設(shè)置UTC日期中的秒數(shù)(

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論