JavaScript框架編程第2/2頁
更新時間:2008年01月16日 20:46:09 作者:
JavaScript框架編程
改變框架的載入頁面
對框架的引用就是對window對象的引用,利用window對象的location屬性,可以改變框架的導(dǎo)航,例如:
window.frames[0].location="1.html";
這就將頁面中第一個框架的頁面重定向到1.html,利用這個性質(zhì),甚至可以使用一條鏈接來更新多個框架。
<frameset rows="50%,50%">
<frame src="1.html" />
<frame src="2.html" />
</frameset>
<!--somecode-->
<a href="frame1.location='3.html;frame2.location='4.html'" >link</a>
<!--somecode-->
引用其他框架內(nèi)的JavaScript變量和函數(shù)
在介紹引用其他框架內(nèi)JavaScript變量和函數(shù)的技術(shù)之前,先來看以下代碼:
<script language="JavaScript" type="text/javascript">
<!--
function hello(){
alert("hello,ajax!");
}
window.hello();
//-->
</script>
如果運行了這段代碼,會彈出“hello,ajax!”的窗口,這正是執(zhí)行hello()函數(shù)的結(jié)果。那為什么hello()變成了window對象的方法呢?因為在一個頁面內(nèi)定義的所有全局變量和全局函數(shù)都是作為window對象的成員。例如:
var a=1;
alert(window.a);
就會彈出對話框顯示為1。同樣的原理,在不同框架之間共享變量和函數(shù),就是要通過window對象來調(diào)用。
例如:一個商品瀏覽頁面由兩個子框架組成,左側(cè)表示商品分類的鏈接;當(dāng)用戶單擊分類鏈接時,右側(cè)顯示相應(yīng)的商品列表;用戶可以單擊商品旁的【購買】鏈接將商品加入購物車。
在這個例子中,可以利用左側(cè)導(dǎo)航頁面來存儲用戶希望購買的商品,因為當(dāng)用戶單擊導(dǎo)航鏈接時,變化的是另外一個頁面,即商品展示頁面,而導(dǎo)航頁面本身是不變的,因此其中的JavaScript變量不會丟失,可以用來存儲全局數(shù)據(jù)。其實現(xiàn)原理如下:
假設(shè)左側(cè)頁面為link.html,右側(cè)頁面為show.html,頁面結(jié)構(gòu)如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title> New Document </title>
</head>
<frameset cols="20%,80%">
<frame src="link.html" />
<frame src="show.html" />
</frameset>
</html>
在show.html中展示的商品旁邊可以加入這樣一條語句:
<a href="void(0)" >加入購物車</a>
其中l(wèi)ink表示導(dǎo)航框架,在link.html頁面中定義了arrOrders數(shù)組來存儲商品的id,函數(shù)addToOrders()用來響應(yīng)商品旁邊【購買】鏈接的單擊事件,它接收的參數(shù)id表示商品的id,例子中是一個id為32068的商品:
<script language="JavaScript" type="text/javascript">
<!--
var arrOrders=new Array();
function addToOrders(id){
arrOrders.push(id);
}
//-->
</script>
這樣,在結(jié)帳頁面或是購物車瀏覽頁面就可以用arrOrders來獲取所有準(zhǔn)備購買的商品。
框架可以使一個頁面劃分為功能獨立的多個模塊,每個模塊之間彼此獨立,但又可以通過window對象的引用來建立聯(lián)系,是Web開發(fā)中的一個重要機制。在Ajax開發(fā)中,還可以利用隱藏框架實現(xiàn)各種技巧,在后面介紹Ajax實例編程時可以發(fā)現(xiàn),無刷新上傳文件以及解決Ajax的前進后退問題都會用到這種技術(shù)。
相關(guān)文章
JavaScript那些不經(jīng)意間發(fā)生的數(shù)據(jù)類型自動轉(zhuǎn)換
JavaScript可以自由的進行數(shù)據(jù)類型轉(zhuǎn)換,但是更多的情況下,是由JavaScript自動轉(zhuǎn)換的。本文就將為大家詳細講解那些不經(jīng)意間發(fā)生的數(shù)據(jù)類型轉(zhuǎn)換,感興趣的同學(xué)可以了解一下2022-02-02javascript學(xué)習(xí)筆記(八)正則表達式
這篇文章本來很早就要寫的,主要介紹一下javascript正則表達式,拖了挺久的,現(xiàn)在整理下,供大家學(xué)習(xí)交流哈!2014-10-10詳解Javascript ES6中的箭頭函數(shù)(Arrow Functions)
箭頭函數(shù),若有了解過coffeeScript的同學(xué),或許對此印象深刻,因為它可以讓語法省略不少,特別是對于回調(diào)函數(shù),會讓代碼更清晰簡潔。下面讓我們一起來學(xué)習(xí)學(xué)習(xí)ES6中的箭頭函數(shù)。2016-08-08javascript學(xué)習(xí)筆記_淺談基礎(chǔ)語法,類型,變量
下面小編就為大家?guī)硪黄猨avascript學(xué)習(xí)筆記_淺談基礎(chǔ)語法,類型,變量。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09Javascript基礎(chǔ)知識(一)核心基礎(chǔ)語法與事件模型
這篇文章主要介紹了Javascript用途及語法,傳統(tǒng)事件及現(xiàn)代事件,是最近這段時間個人學(xué)習(xí)javascript的一些心得,分享給大家,有需要的朋友可以參考下2014-09-09javascript中的=等號個數(shù)問題兩個跟三個有什么區(qū)別
一個等號就是個賦值的作用,主要問題在于兩個跟三個等號的區(qū)別,想必有很多的朋友都不知道吧,在本文有個不錯的示例主要介紹下兩者到底有什么區(qū)別,感興趣的朋友不要錯過2013-10-10addEventListener()第三個參數(shù)useCapture (Boolean)詳細解析
true的觸發(fā)順序總是在false之前;如果多個均為true,則外層的觸發(fā)先于內(nèi)層;如果多個均為false,則內(nèi)層的觸發(fā)先于外層2013-11-11