av网站免费线看精品_国产做a爱视频免费不_深爱激情网开心五月天_伊人五月天在线视频网

 
HTML-加速、再加速
發(fā)布時間:2008-05-07   瀏覽次數(shù):1227176

HTML-加速、再加速

web開發(fā)人員是否必須掌握復(fù)雜的組件技術(shù)才能加快html頁面的訪問速度?答案是:不一定!實際上,有許多關(guān)于HTML與DHTML方面的技巧,它們原理簡單而且上手容易。無論是技術(shù)高超的老手,還是初涉編程的菜鳥,領(lǐng)會這些都十分必要。
明顯HTML,暗渡“公用腳本”

減少web頁面下載時間的關(guān)鍵是設(shè)法減小文件大小。當(dāng)多個頁面共用一些成分內(nèi)容時,可以考慮將這些公用部分單獨分離出來。比如:我們可以將多個HTML頁面都用到的腳本程序編寫成獨立存在的.js文件,然后再在頁面中按如下方式調(diào)用它:

<script src="myfile.js"></script>

這樣,公用文件只需要下載一次,然后進(jìn)入緩沖區(qū)。等下次再次調(diào)用包含公用文件的html頁面時,下載時間明顯減少。

讓樣式表內(nèi)容進(jìn)入地下工作

CSS是HTML裝扮器,一個漂亮的Web頁面不可能沒有它。HTML頁面中有多種引用CSS的方法,不同的方法導(dǎo)致的效率也不一樣。通常,我們可以將定義于<style></style>間的樣式控制代碼提取出來,保存到單獨的.css文件中,然后在HTML頁面中以<LINK>標(biāo)記或者@import標(biāo)記的方式進(jìn)行引用:

<style>
@import url("mysheet1.css");
</style>


請注意2點:1、.css文件中無需包括<style>標(biāo)記;2、@import和LINK標(biāo)記要定義在HTML頁面的HEAD部分。

寶貴內(nèi)存節(jié)省兩法

盡量減少HTML頁面占用的內(nèi)存空間是加快頁面下載速度的一個有效方法。在這方面,有2個需要注意的問題:

1、使用同一種腳本語言

HTML頁面離不開腳本程序的支持,我們經(jīng)常會在頁面中嵌入多種腳本語言,比如JavaScript與VBScript。但是,不知你發(fā)覺沒有:這樣的混合使用減慢了頁面的訪問速度。原因在于:要解釋并運行多種腳本代碼,必須在內(nèi)存中裝載多種腳本引擎。所以,請盡量在頁面中使用同一種腳本語言編寫代碼。

2、巧用IFrame

你使用過<IFRAME>標(biāo)記嗎?它可是一個非常美妙的功能。如果要在一個HTML文檔中包含第2個頁面的內(nèi)容,通常的方法是使用<FRAMESET>標(biāo)記。但是有了<IFRAME>,一切變得簡單了。比如,開發(fā)一個文檔預(yù)覽頁面,可以在左邊放置一系列主題,在右邊放置一個IFRAME,其中包含要預(yù)覽的文檔;當(dāng)鼠標(biāo)掠過左邊的每一個主題鏈接時,在右邊建立一個新的IFRAME以預(yù)覽文檔。這樣做,代碼效率無疑是的,但同時導(dǎo)致了繁重的處理過程,最終是緩慢的速度。

沒關(guān)系,我們有辦法:只使用單一的IFRAME。當(dāng)鼠標(biāo)指向一個新主題時,只需要修改IFRAME元素的SRC屬性即可。這樣,任何時間內(nèi)只會有一個預(yù)覽文檔保留在內(nèi)存。

擇優(yōu)選用動畫定位屬性

每天上網(wǎng)瀏覽頁面,你一定會看到許多動畫效果。比如,一個可愛的小兔子在頁面上來回地走動 ... 實現(xiàn)這個效果的核心技術(shù)是CCS定位。通常,我們是使用element.style.left和element.style.top2個屬性來達(dá)到圖形定位的目的。但是,這樣做會產(chǎn)生一些問題:left屬性返回一個字符串,并且其中包含了度量單位(比如100px)。因此,要設(shè)定新的位置坐標(biāo),必須首先對這個字符串返回值進(jìn)行處理,然后才能賦值,象下面一樣:

dim stringLeft, intLeft

stringLeft = element.style.left

intLeft = parseInt(stringLeft)

intLeft = intLeft + 10

element.style.left = intLeft;

你一定會感覺做這么點事情竟要編寫這么復(fù)雜的代碼,是否有更簡潔的方法?當(dāng)然有!請看這4個屬性:posLeft、posTop、posWidth 和 posHeight,它們對應(yīng)于相應(yīng)字符串返回值的點數(shù)數(shù)值。好了,使用這些屬性重新編寫代碼實現(xiàn)上面代碼實現(xiàn)的功能:

element.style.posLeft += 10

代碼短小、速度卻更快!

循環(huán)控制多個動畫

說到制作動畫效果,當(dāng)然離不開定時器的運用。通常的方法是使用window.setTimeout來不斷地定位頁面上的元素。但是,如果頁面上有多個動畫要顯示,是不是要設(shè)定多個定時器呢?答案是No!原因很簡單:定時器功能將消耗掉大量寶貴的系統(tǒng)資源?墒俏覀?nèi)阅茉陧撁嫔峡刂贫鄠動畫,技巧是使用一個循環(huán)。在循環(huán)中根據(jù)不同的變量值控制相應(yīng)動畫的位置,整個循環(huán)中只使用一個window.setTimeout()函數(shù)調(diào)用。

Visibility快于Display

讓圖畫時隱時現(xiàn)會創(chuàng)造很有趣的效果,有2種方法可以實現(xiàn)這個目的:使用CSS的visibility屬性或者display屬性。對于位置元素,diaplay和visibility具有同樣的效果。兩者的區(qū)別在于:設(shè)置為display:none的元素將不再占用文檔流的空間,而設(shè)置為visibility:hidden的元素仍然保留原位置。

但是如果要處理位置的元素,使用visibility會更快。

從小處著手

編寫DHTML網(wǎng)頁的一個重要提示是:從小處著手。初次編寫DHTML頁面時,一定不要試圖在頁面中使用你了解到的全部DHTML功能。每次可以只使用一個單一的新特征,并且仔細(xì)地觀察由此產(chǎn)生的變化。如果發(fā)現(xiàn)性能有所下降,可以快速地找到為什么。

腳本的DEFER化

DEFER是腳本程序強大功能中的一個“無名英雄”。你可能從沒有使用過它,但是看完這里的介紹后,相信你離不開它。它告訴瀏覽器Script段包含了無需立即執(zhí)行的代碼,并且,與SRC屬性聯(lián)合使用,它還可以使這些腳本在后臺被下載,前臺的內(nèi)容則正常顯示給用戶。

請注意兩點:

1、不要在defer型的腳本程序段中調(diào)用document.write命令,因為document.write將產(chǎn)生直接輸出效果。

2、而且,不要在defer型腳本程序段中包括任何立即執(zhí)行腳本要使用的全局變量或者函數(shù)。

保持同一URL的大小寫一致性

我們都知道UNIX服務(wù)器是大小寫敏感的,但是你知道嗎:Internet Explorer的緩沖區(qū)也是區(qū)別對待大小寫字符串的。因此,作為web開發(fā)者,一定要記住保持相同鏈接的URL字符串在不同位置的大小寫的一致性。否則,會在瀏覽器的緩沖區(qū)中存放同一位置的不同文件備份,也增加了下載同一位置內(nèi)容的請求次數(shù)。這些都無疑降低了web訪問效率。所以請謹(jǐn)記:同一位置的URL,在不同頁面中請保持URL字符串的大小寫一致性。

讓標(biāo)記有始有終

自己編寫或者查看他人的HTML代碼時,我們一定都遇到過標(biāo)記有頭無尾的情況。比如:

<P>有頭無尾標(biāo)記舉例
<UL>
<LI>個
<LI>第二個
<LI>第三個
</UL>

很明顯,上面的代碼中缺少三個</LI>結(jié)束標(biāo)記。但是這并不妨礙它的正確執(zhí)行。在HTML中,這樣的標(biāo)記還有一些,例如FRAME、IMG和P。

可是請不要偷懶,請將結(jié)束標(biāo)記寫完整,這樣做不僅使HTML代碼格式規(guī)范,更可以加速頁面的顯示速度。因為Internet Explorer將不會花費時間判斷和計算段落或者列表項目在哪里結(jié)束。

<P>有頭有尾標(biāo)記舉例</P>
<UL>
<LI>個</LI>
<LI>第二個</LI>
<LI>第三個</LI>
</UL>

OK,以上列舉了有關(guān)加速HTML頁面的10個處理技巧,描述這些很簡單,但是只有真正領(lǐng)會并掌握其中的本質(zhì),并且舉一反三,才會編寫出更快、更好的程序。

立即預(yù)約