<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    即使世界明天毀滅,我也要在今天種下我的葡萄樹。
    posts - 112, comments - 14, trackbacks - 0, articles - 11

    HTML優化加快網頁速度

    Posted on 2007-03-30 14:36 閱讀(283) 評論(0)  編輯  收藏
    web開發人員是否必須掌握復雜的組件技術才能加快html頁面的訪問速度?答案是:不一定!實際上,有許多關于HTML與DHTML方面的技巧,它們原理簡單而且上手容易。無論是技術高超的老手,還是初涉編程的菜鳥,領會這些都十分必要。

    ???? 明顯HTML,暗渡“公用腳本”

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

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

    ???? 這樣,公用文件只需要下載一次,然后就進入緩沖區。等下次再次調用包含公用文件的html頁面時,下載時間明顯減少。

    ???? 讓樣式表內容進入地下工作

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

    ???? <style>?

    ???? @import?url("mysheet1.css");?

    ???? </style>?


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

    ???? 寶貴內存節省兩法

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

    ???? 1、使用同一種腳本語言

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

    ???? 2、巧用IFrame

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

    ???? 沒關系,我們有辦法:只使用單一的IFRAME。當鼠標指向一個新主題時,只需要修改IFRAME元素的SRC屬性即可。這樣,任何時間內只會有一個預覽文檔保留在內存。

    ???? 擇優選用動畫定位屬性

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

    ???? dim?stringLeft,?intLeft?

    ???? stringLeft?=?element.style.left?

    ???? intLeft?=?parseInt(stringLeft)?

    ???? intLeft?=?intLeft?+?10?

    ???? element.style.left?=?intLeft;?

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

    ???? element.style.posLeft?+=?10

    ???? 代碼短小、速度卻更快!

    ???? 循環控制多個動畫

    ???? 說到制作動畫效果,當然離不開定時器的運用。通常的方法就是使用window.setTimeout來不斷地定位頁面上的元素。但是,如果頁面上有多個動畫要顯示,是不是就要設定多個定時器呢?答案是No!原因很簡單:定時器功能將消耗掉大量寶貴的系統資源。可是我們仍能在頁面上控制多個動畫,技巧就是使用一個循環。在循環中根據不同的變量值控制相應動畫的位置,整個循環中只使用一個window.setTimeout()函數調用。

    ???? Visibility快于Display

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

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

    ???? 從小處著手

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

    ???? 腳本的DEFER化

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



    ???? 最后請注意兩點:

    ???? 1、不要在defer型的腳本程序段中調用document.write命令,因為document.write將產生直接輸出效果。

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

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

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

    ???? 讓標記有始有終

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

    ???? <P>有頭無尾標記舉例?
    ???? <UL>?
    ???? <LI>第一個
    ???? <LI>第二個
    ???? <LI>第三個
    ???? </UL>?

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

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

    ???? <P>有頭有尾標記舉例</P>?
    ???? <UL>?
    ???? <LI>第一個</LI>?
    ???? <LI>第二個</LI>?
    ???? <LI>第三個</LI>?
    ???? </UL>?

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

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: g0g0人体全免费高清大胆视频| 国产亚洲欧美在线观看| 中文字幕乱码一区二区免费| 亚洲人成无码网站久久99热国产| 成人精品国产亚洲欧洲| 国产91久久久久久久免费| 国产精品无码亚洲精品2021| 国产无遮挡裸体免费视频 | 久久久www成人免费毛片| 亚洲第一男人天堂| 午夜一区二区免费视频| 粉色视频免费入口| 亚洲综合色自拍一区| 精品免费tv久久久久久久 | 日本亚洲免费无线码| 国产一级一片免费播放| 视频免费1区二区三区| 久久亚洲国产欧洲精品一| 精品无码免费专区毛片| 亚洲欧美黑人猛交群| 亚洲免费日韩无码系列| 精品视频在线免费观看| 亚洲一区二区三区高清视频| 日本免费一区尤物| a级午夜毛片免费一区二区| 久久精品国产亚洲av水果派| 久久精品免费一区二区喷潮| 九九久久精品国产免费看小说| 国产日韩亚洲大尺度高清| 亚洲高清视频免费| 蜜桃传媒一区二区亚洲AV| 久久影院亚洲一区| 久久国产免费福利永久| 杨幂最新免费特级毛片| 久久精品国产亚洲AV无码偷窥| 日韩免费福利视频| 一级毛片免费播放| 色噜噜的亚洲男人的天堂| 亚洲成人动漫在线| 国产一区二区三区免费视频| 日韩免费无码一区二区三区|