欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何快速的呈現(xiàn)我們的網(wǎng)頁(yè)的技巧整理

 更新時(shí)間:2007年07月01日 00:00:00   作者:  

前幾天小芳同學(xué)一直在群發(fā)起一些加速的話題,我已經(jīng)把聊天記錄抽出來(lái),正打算整理出份像樣的,沒(méi)想到小芳同學(xué)非常速度的出了這篇。我的就省掉了,挖哈哈。

特別說(shuō)一下了,這些方案并非適合所有的網(wǎng)站,很多部分有的網(wǎng)站還是不要做反而會(huì)更好。如果你還有更多的想法,可以到這里討論或者評(píng)論,我只是歸檔成為方便閱讀的,對(duì)了論壇和群討論的另一些結(jié)果如果有價(jià)值我也會(huì)補(bǔ)充進(jìn)來(lái)。

如何快速的呈現(xiàn)我們的網(wǎng)頁(yè) 作者:flashsoft,(內(nèi)容被我略修刪過(guò))。

一.我們需達(dá)解決的麻煩

  • 減少HTTP請(qǐng)求數(shù). 減少HTTP請(qǐng)求數(shù)有什么好處
    • 降低服務(wù)器跟客戶端的建立和消除HTTP請(qǐng)求和響應(yīng)Header的開(kāi)銷(xiāo)
    • 減少服務(wù)器為HTTP連接的進(jìn)程和線程的開(kāi)銷(xiāo),如果可能,還會(huì)包括GZIP壓縮的CPU開(kāi)銷(xiāo).
  • 減小被請(qǐng)求文件大小, 減少請(qǐng)求數(shù)據(jù)占用的網(wǎng)絡(luò)帶寬.
  • 讓用戶更快的看到想要的結(jié)果.
  • 提高客戶端渲染速度.
  • 讓瀏覽器同時(shí)能請(qǐng)求更多的數(shù)據(jù).
  • 提高服務(wù)器相應(yīng)速度.
  • 通過(guò)版本化控制客戶端Cache.

二.如何解決我們的麻煩

A.如何減少HTTP請(qǐng)求數(shù)

  1. 合并JS文件跟CSS文件。
  2. 合并框架圖片以及相對(duì)變動(dòng)較少的圖片成一張,通過(guò)CSS背景切割來(lái)完成渲染,比如:加速圖片顯示。
  3. 合理使用本地Cache來(lái)緩存JS/CSS/IMAGE。
  4. 合理使用UserData緩存JS文件,對(duì)于FF用戶可以單獨(dú)請(qǐng)求服務(wù)器,這樣能解決80%用戶的問(wèn)題.代碼可以蓉兒(meizz)的js framework1。
  5. 把JS跟CSS合并成一個(gè)文件

B.減小被請(qǐng)求文件大小,減少請(qǐng)求數(shù)據(jù)占用的網(wǎng)絡(luò)帶寬

  1. 壓縮JS體積:刪除JS中空白換行,注釋,混淆把長(zhǎng)變量換成短變量;
  2. 壓縮CSS體積:刪除CSS注釋、寫(xiě)法盡量用簡(jiǎn)寫(xiě);
  3. 使用(X)HTML+CSS方式搭建網(wǎng)站結(jié)構(gòu),提高CSS重用性,來(lái)減少(X)HTML文件大?。?
  4. 使用服務(wù)器端GZIP壓縮JS/ CSS文件,縮小傳輸文件大小。附注:Apache1跟Apache2的GZIP的效率跟方式不一樣的,根據(jù)需要自行選擇。

嗷嗷補(bǔ)充說(shuō)明:壓縮、合并JS和CSS都由程序處理。而不是自己手動(dòng)去縮刪,不然不利于后期維護(hù)。

C.讓用戶更快的看到想要的結(jié)果

用戶對(duì)于一個(gè)站點(diǎn)的白頁(yè)的忍受時(shí)間根據(jù)統(tǒng)計(jì)是8-12秒。白頁(yè)的產(chǎn)生可能由于各種原因引起,我們能做的就是怎么讓用戶能變的稍微能等待更久。

  • 方案1.多做一個(gè)引導(dǎo)頁(yè),讓用戶體會(huì)其中的變化
    案例:mail.aol.com中的loading引導(dǎo)頁(yè)
  • 方案2.優(yōu)先載入頁(yè)面結(jié)構(gòu)以及結(jié)構(gòu)圖片,后一步載入當(dāng)前頁(yè)面數(shù)據(jù),再后一步載入Iframe,Flash等數(shù)據(jù).讓用戶盡早的看到被打開(kāi)頁(yè)面的希望.

D.提高客戶端渲染速度

這個(gè)問(wèn)題就比較泛泛了,影響客戶端的渲染速度有多方面的,主要目的都是提高程序方面的效率.

  1. 對(duì)于大索引的結(jié)構(gòu),盡可能的少用索引訪問(wèn),能用訪問(wèn)兄弟節(jié)點(diǎn)的方式盡可能用訪問(wèn)兄弟節(jié)點(diǎn)的方式.
  2. 字符串拼接盡可能用數(shù)組方式
  3. 大規(guī)模添加節(jié)點(diǎn)數(shù)據(jù),請(qǐng)不要使用appendChild方式,盡量使用類(lèi)似innerHTML的insertAdjacentHTML方式,FF下需修正2

E.讓瀏覽器同時(shí)能請(qǐng)求更多的數(shù)據(jù).

瀏覽器默認(rèn)只是支持單域名同時(shí)有兩個(gè)HTTP請(qǐng)求,使用多域名將能把請(qǐng)求數(shù)提高,在網(wǎng)絡(luò)條件優(yōu)良的情況下,能更快的下載數(shù)據(jù),呈現(xiàn)結(jié)果.

F.提高服務(wù)器相應(yīng)速度

對(duì)于需快速響應(yīng)的文件,把其放入快速響應(yīng)的服務(wù)器,應(yīng)該是不錯(cuò)的方案,優(yōu)化方案請(qǐng)系統(tǒng)儲(chǔ)備組提供.

G.通過(guò)版本化控制客戶端Cache.

通常js/css這類(lèi)文件改動(dòng)比較頻繁,但是為了加載速度變快,我們有可能需要設(shè)定這類(lèi)文件的過(guò)期時(shí)間為幾天后,這樣我們碰到的問(wèn)題就是,如何及時(shí)更新這些在cache的文件?
通過(guò)一個(gè)簡(jiǎn)單的配置,通過(guò)修改JS的版本來(lái)及時(shí)告訴瀏覽器,這些文件必須重新請(qǐng)求了,不要繼續(xù)使用瀏覽器cache中的數(shù)據(jù). 方案有好幾個(gè):

  1. 手動(dòng)改這些js的文件名
  2. 手動(dòng)改這些js的路徑
  3. 通過(guò)URL Rewrite方式來(lái)改重定位js路徑
  4. 通過(guò)一個(gè)在高響應(yīng)服務(wù)器上的一個(gè)js配置告知頁(yè)面,這個(gè)頁(yè)面該鏈接哪些JS文件
  5. 大版本不變,小版本不斷追加,等一定時(shí)間后,統(tǒng)一更新,高效利用cache

標(biāo)注

  1. meizz的js framework還沒(méi)出正式版,有興趣在CSDN的頁(yè)面翻一下
  2. Firefox修正方式
    function addHTML(oParentNode, sHTML) {
    if(window.addEventListener) {// for MOZ
    var oRange = oParentNode.ownerDocument.createRange();
    oRange.setStartBefore(oParentNode);
    var oFrag = oRange.createContextualFragment(sHTML);
    oParentNode.appendChild(oFrag);
    }
    else {// for IE5+
    oParentNode.insertAdjacentHTML("BeforeEnd", sHTML);
    }
    }

相關(guān)文章

  • layui關(guān)閉層級(jí)、簡(jiǎn)單監(jiān)聽(tīng)的實(shí)例

    layui關(guān)閉層級(jí)、簡(jiǎn)單監(jiān)聽(tīng)的實(shí)例

    今天小編就為大家分享一篇layui關(guān)閉層級(jí)、簡(jiǎn)單監(jiān)聽(tīng)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • javascript入門(mén)教程基礎(chǔ)篇

    javascript入門(mén)教程基礎(chǔ)篇

    這篇文章主要介紹了javascript入門(mén)教程,全部?jī)?nèi)容都是javascript的基礎(chǔ)知識(shí),內(nèi)容很全面,特別適合剛剛學(xué)習(xí)javascript的朋友學(xué)習(xí),希望大家仔細(xì)閱讀javascript教程。
    2015-11-11
  • 淺談html轉(zhuǎn)義及防止javascript注入攻擊的方法

    淺談html轉(zhuǎn)義及防止javascript注入攻擊的方法

    下面小編就為大家?guī)?lái)一篇淺談html轉(zhuǎn)義及防止javascript注入攻擊的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b

    js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b

    這篇文章主要介紹了js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • 微信小程序?qū)崿F(xiàn)播放音頻功能

    微信小程序?qū)崿F(xiàn)播放音頻功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)播放音頻功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 基于JavaScript實(shí)現(xiàn)貪吃蛇游戲

    基于JavaScript實(shí)現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)貪吃蛇游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 微信小程序轉(zhuǎn)發(fā)事件實(shí)現(xiàn)解析

    微信小程序轉(zhuǎn)發(fā)事件實(shí)現(xiàn)解析

    這篇文章主要介紹了微信小程序轉(zhuǎn)發(fā)事件實(shí)現(xiàn)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • Javascript&DHTML基礎(chǔ)知識(shí)

    Javascript&DHTML基礎(chǔ)知識(shí)

    首先請(qǐng)下載JScript.chm這本手冊(cè),無(wú)論新手老手,有一本手冊(cè)是免不了的,特別是對(duì)于新手,如果你沒(méi)有空翻犀牛書(shū),那么這本手冊(cè)將是你了解這門(mén)語(yǔ)言的首選。下面所講的大多數(shù),手冊(cè)上可以沒(méi)有提及,或提及很少的內(nèi)容。
    2008-07-07
  • JS常用字符串方法(推薦)

    JS常用字符串方法(推薦)

    下面小編就為大家?guī)?lái)一篇JS常用字符串方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • JavaScript實(shí)現(xiàn)網(wǎng)站訪問(wèn)次數(shù)統(tǒng)計(jì)代碼

    JavaScript實(shí)現(xiàn)網(wǎng)站訪問(wèn)次數(shù)統(tǒng)計(jì)代碼

    每個(gè)網(wǎng)站管理者,都必須知道每天有多少人訪問(wèn)了本站,需要一個(gè)網(wǎng)站訪問(wèn)次數(shù)功能來(lái)滿足需求,本篇文章主要介紹了JavsScript實(shí)現(xiàn)網(wǎng)站訪問(wèn)次數(shù)統(tǒng)計(jì)代碼,需要的朋友可以參考下
    2015-08-08

最新評(píng)論