摘要:當(dāng)這些系統(tǒng)的用戶界面元素產(chǎn)生某些事件時,會運(yùn)行特定的代碼以作響應(yīng)。我們將注意力放在程序設(shè)計上,特別是放在事件驅(qū)動的程序設(shè)計上,所以重點還在。
6.1 6.1.1 在研究受事件驅(qū)動的程序時,傾向于關(guān)注四個機(jī)制
因為許多事件都與人們可以看到的用戶界面元素(按鈕、文本字段、滑動塊)相關(guān)聯(lián),所以事件驅(qū)動計算的一個關(guān)鍵要素就是用于定義用戶界面元素的機(jī)制
由于檢測到的事件經(jīng)常會引用或修改一個腳本內(nèi)的其他用戶界面元素,所以應(yīng)當(dāng)提供一種一編程方式訪問用戶界面元素的機(jī)制。
因為用戶界面元素要響應(yīng)事件——包括但不限于單擊鼠標(biāo)、鼠標(biāo)移動、擊鍵、語音與手勢檢測、鍵盤焦點改變、時間流逝、網(wǎng)絡(luò)數(shù)據(jù)到達(dá),所以事件驅(qū)動的系統(tǒng)提供一種用于指定代碼的機(jī)制,再出發(fā)特定事件時執(zhí)行此代碼。
許多事件都伴有補(bǔ)充信息。例如鼠標(biāo)事件涉及鼠標(biāo)坐標(biāo)、一個或多個鼠標(biāo)按鈕;鍵盤事件涉及一個特定鍵,還可能有一個或多個修改鍵。因此事件驅(qū)動的系統(tǒng)提供一種用于讀取事件專屬信息的機(jī)制。
6.2定義用戶界面元素之前曾提到,JavaScript的設(shè)計就是要內(nèi)嵌在托管系統(tǒng)中,比如Web服務(wù)器、圖像編輯器、字處理器和類似系統(tǒng)。當(dāng)這些系統(tǒng)的用戶界面元素產(chǎn)生某些事件時,會運(yùn)行特定的JavaScript代碼以作響應(yīng)。盡管JavaScript并沒有自己定義這些元素,但它卻提供了一種非常好的功能,可以將函數(shù)用作對象的屬性,與這些用戶界面元素完全對應(yīng)。
例如,在一個Web環(huán)境中,這些元素是通過以HTML編寫的結(jié)構(gòu)化文檔來提供的,這些文檔或者由Web服務(wù)器通過互聯(lián)網(wǎng)提供,或者作為.html文件存儲在本地計算機(jī)上,然后由Web渲染器為我們熟悉的可視形式。沒有JavaScript,這些頁面就是靜態(tài)的,也就是說,一旦加載,它們的內(nèi)容就不能改變。改變顯示內(nèi)容的唯一方法就是單擊一個鏈接,為一個新頁面重新啟動"鏈接——渲染"周期。利用JavaScript,web頁面獲得了觸發(fā)自我修改的能力,從而可以根據(jù)用戶與頁面內(nèi)容的互動變?yōu)閯討B(tài)的。
6.2.1 Web頁面是結(jié)構(gòu)化文檔Temperature Conversion
如上面這段"溫度轉(zhuǎn)換器"的Web頁面的節(jié)點結(jié)構(gòu)。
HTML定義了一組可供使用的節(jié)點和屬性,還有用于構(gòu)建正確結(jié)構(gòu)的規(guī)則。創(chuàng)建HTML文檔的通常形式是:編寫一系列用標(biāo)簽表示元素的字符,這些標(biāo)簽或者為開始標(biāo)簽、結(jié)束標(biāo)簽或者為空標(biāo)簽。
定義HTML語法的全套規(guī)則非常復(fù)雜,但我們可以由以下規(guī)則入門。
文檔的開頭應(yīng)當(dāng)是一個文檔類型聲明,告訴瀏覽器希望使用哪種HTML版本,目前一般都是HTML5.
Web頁面應(yīng)當(dāng)僅包含一個html元素,它恰好由兩部分組成,其順序為:head元素后面跟有一個body元素。
頭元素中包含文檔的相關(guān)信息,其中有一些子元素,用于表示頁面標(biāo)題(title)、到其他web資源的鏈接(link)、樣式信息(style)、腳本(script)、一般信息(meta)及其他。強(qiáng)烈建議提供一個meta元素,作為head的第一個子元素,告訴瀏覽器,你的文檔存儲時采用了哪種字符編碼。
主體中包含文本元素和塊元素。文本可以用行內(nèi)元素標(biāo)記,這些元素可用于以下目的:表示強(qiáng)調(diào)(em)、著重強(qiáng)調(diào)(strong)、匿名(abbrev)、引用(q)、引文(cite)、上標(biāo)(sup)、下標(biāo)(sub)、到其他文檔的鏈接(a)、一般內(nèi)置跨區(qū)(span)等等。
有幾個用于表示多媒體內(nèi)容的元素,其行為方式也與行內(nèi)元素相同:img、audio、video、object、embed。audio和video是HTML5新增元素;object和embed用于瀏覽器插件的百寶囊元素。
一些元素設(shè)計上需要子組件:有序、無序列表li;定義列表dt和dd;表格表頭thead、主體tbody、頁腳tfoot、每一個都有行tr,單元格可以是標(biāo)題th,也可以是正常表格數(shù)據(jù)td。
經(jīng)典的用戶界面元素:input(button、text)、select、textarea、單選radio、復(fù)選checkbox等等。
HTML5引入了outpt、keygen、progress、meter、command,還有其他一些input類型,如number、date、email。
一些元素既可以出現(xiàn)在標(biāo)題中,也可以出現(xiàn)在主體中,一些元素既可以充當(dāng)塊元素,也可以充當(dāng)行內(nèi)元素。
我們將注意力放在程序設(shè)計上,特別是放在事件驅(qū)動的程序設(shè)計上,所以重點還在JavaScript。
6.3 以編程方式訪問用戶界面元素下面將說明JavaScript如何使用一種稱為文檔對象模型(Document Object Model,DOM)的“橋接技術(shù)”來讀寫這一用戶界面,并進(jìn)行處理。
6.3.1 document對象document就是一種宿主對象,可以在任何時間、任何位置供Web瀏覽器中運(yùn)行的任何JavaScript代碼使用。
alert(document)
至少,它向你證明了:JavaScript不用費(fèi)什么力氣就能看到document,只需用名字調(diào)用它即可。現(xiàn)在再簡單看看document的一些屬性。
var i = 0; for (var prototy in document) { console.log(prototy); i++; if (i>4) { break; } };
[Web瀏覽器] "vlinkColor" /javascript/test.html (11)
[Web瀏覽器] "linkColor" /javascript/test.html (11)
[Web瀏覽器] "alinkColor" /javascript/test.html (11)
[Web瀏覽器] "fgColor" /javascript/test.html (11)
[Web瀏覽器] "bgColor" /javascript/test.html (11)
看到了控制臺內(nèi)的輸出,每個都有一個屬性名,比如bgColor、width或getElementById。這里無法給出一個確定不變的列表,因為不同瀏覽器可能會按不同的順序列出document的屬性,甚至包含一些其他瀏覽器不被支持的屬性。
i計數(shù)器將console.log的屬性名稱限制為僅有五個,有一種更方便的方式查看document的所有屬性名稱。
for (var property in document) { document.write(""+property+""); }
注意上面代碼如何改變了web窗口中的實際內(nèi)容。這是document的關(guān)鍵屬性之一,它被直接“連線”到一個web頁面。document中的write函數(shù)將給定字符串直接發(fā)送個頁面;我們用這個函數(shù)逐字寫出其內(nèi)容。如果在處理頁面的同時調(diào)用write,它的行為更像是一個打字員,向當(dāng)前頁面注入HTML,但是如果在加載頁面之后在調(diào)用write,將會創(chuàng)建一個新的空白web頁面,并向其添加文本。
不難想象一個函數(shù)可以怎樣修改web瀏覽器的內(nèi)容。畢竟是一個函數(shù),可以輕松的包含代碼,用于修改顯示內(nèi)容。
var footer = document.getElementById("footer"); footer.innerHTML = "document properties:
"; var properties = []; for (var property in document) { properties.push(property+" "); } footer.innerHTML = ""+properties.join("
"
")+"
這個腳本中,document.getElementById("footer")返回運(yùn)行期頁面的一些元素,但這并不是什么非同尋常的事情。注意,其中只有一次賦值操作,就是為這個對象的innerHTML屬性指定了一個字符串,而這一賦值操作改變了web頁面,其效果馬上就顯示了出來。這樣就使JavaScript與相關(guān)文檔之間的互動顯得非常自然,富有凝聚力:設(shè)定一個值,馬上就能看到結(jié)果。
6.3.4 操控用戶界面空間 Web頁面決定著JavaScript的生存周期,當(dāng)Web頁面被關(guān)閉、刷新、替換,由下一頁面上的DOM腳本/變量接管時,對象、變量、函數(shù)和所有其他一切都將被拋棄。這就是"JavaScript"的生命輪回。 6.3.6 遍歷DOM對document宿主對象再做一點深入剖析。我們已經(jīng)看到,document是JavaScript代碼借以修改或更新Web頁面的渠道。這個宿主對象表示的就是文檔樹頂部的文檔節(jié)點,事實上,這些樹中的所有節(jié)點都是用JavaScript宿主對象表示的;和所有對象一樣,它們擁有屬性。DOM對象,包括document自身,具有以下一個或多個屬性。
nodeType:1~12范圍內(nèi)的一個整數(shù),用來描述節(jié)點的類型。例如:1表示元素,3表示文本,8表示注釋,9表示文檔節(jié)點本身
nodeValue:節(jié)點的內(nèi)容,如文本節(jié)點中的文本。
childNodes:一個與數(shù)組類似的對象,其中childNodes[0]引用了該對象的第一個子節(jié)點,childNodes[1]引用第二個,以此類推。每個子節(jié)點又可以擁有自己的childNodes屬性。
有一些DOM對象就是元素(nodeType===1),它們有兩個很有用的屬性。tagName:元素的名字
attributes:一個類似于數(shù)組的對象,其中包含"名稱-值對"形式的屬性。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/83063.html
摘要:三種使用構(gòu)造函數(shù)創(chuàng)建對象的方法和的作用都是在某個特殊對象的作用域中調(diào)用函數(shù)。這種方式還支持向構(gòu)造函數(shù)傳遞參數(shù)。叫法上把函數(shù)叫做構(gòu)造函數(shù),其他無區(qū)別適用情境可以在特殊的情況下用來為對象創(chuàng)建構(gòu)造函數(shù)。 一、工廠模式 工廠模式:使用字面量和object構(gòu)造函數(shù)會有很多重復(fù)代碼,在此基礎(chǔ)上改進(jìn)showImg(https://segmentfault.com/img/bVbmKxb?w=456&...
摘要:繼承的是超類型中構(gòu)造函數(shù)中的屬性,如上繼承了屬性,但沒有繼承原型中的方法。上述造成的結(jié)果是子類型實例中有兩組超類型的構(gòu)造函數(shù)中定義的屬性,一組在子類型的實例中,一組在子類型實例的原型中。 ECMAScript只支持實現(xiàn)繼承,主要依靠原型鏈來實現(xiàn)。與實現(xiàn)繼承對應(yīng)的是接口繼承,由于script中函數(shù)沒有簽名,所以無法實現(xiàn)接口繼承。 一、原型鏈 基本思想:利用原型讓一個引用類型繼承另一個引用...
摘要:我們將使用,這是一個現(xiàn)代,簡單,漂亮的框架,在內(nèi)部使用并將響應(yīng)式編程概念應(yīng)用于前端編程。驅(qū)動程序采用從我們的應(yīng)用程序發(fā)出數(shù)據(jù)的,它們返回另一個導(dǎo)致副作用的。我們將使用來呈現(xiàn)我們的應(yīng)用程序。僅采用長度超過兩個字符的文本。 Rxjs 響應(yīng)式編程-第一章:響應(yīng)式Rxjs 響應(yīng)式編程-第二章:序列的深入研究Rxjs 響應(yīng)式編程-第三章: 構(gòu)建并發(fā)程序Rxjs 響應(yīng)式編程-第四章 構(gòu)建完整的We...
摘要:把原型修改為另外一個對象就等于切斷了構(gòu)造函數(shù)與最初原型之間的聯(lián)系。組合使用構(gòu)造函數(shù)模式動態(tài)原型模式通過檢查某個應(yīng)該存在的方法是否有效,來決定是否需要初始化原型。 理解對象 屬性類型 數(shù)據(jù)屬性 數(shù)據(jù)屬性包含一個數(shù)據(jù)值的位置。在這個位置可以讀取和寫入值。數(shù)據(jù)屬性有 4 個描述其行為的特性。 [[Configurable]] :表示能否通過 delete 刪除屬性從而重新定義屬性,能否修...
閱讀 3280·2021-09-30 09:47
閱讀 2296·2021-09-10 10:51
閱讀 1897·2021-09-08 09:36
閱讀 2931·2019-08-30 12:56
閱讀 3034·2019-08-30 11:16
閱讀 2627·2019-08-29 16:40
閱讀 2999·2019-08-29 15:25
閱讀 1637·2019-08-29 11:02