如何大幅提升
網站建設完成后打開的速度 Web性能:11個必讀技巧,可幫助您加快網站速度
我們可以向我們的網站添加更多功能,并擁有比以往更多的工具和技術。但是,不利的一面是,我們的選擇可能會極大地降低網站的速度,從而使客戶感到沮喪(在2018年的一項調查中,有80%的用戶表示加載緩慢的網站比暫時關閉的網站更令人沮喪)。如果在緩慢的網絡條件或低端設備上無法訪問站點或無法響應站點,則它甚至可以完全排除潛在客戶。
網站性能優化對業務的影響已得到充分證明。例如,時尚零售商Missguided 將頁面加載時間中位數減少了4秒,收入增加了26%。在下面觀看有關此內容的演講:
其中很多是關于提高知名度的,所以我們邀請了七位專家來提出一些技巧,以幫助提高您的網站的性能。
模板圖標
培養技能的資源
獲得免費的項目計劃模板副本,直接發送到您的收件箱。
電子郵件
輸入您的電子郵件地址
輸入您的電子郵件-我們還將向您發送與Shopify相關的營銷電子郵件。您可以隨時取消訂閱。
我們的虛擬齒輪正在轉動。
請注意,
我們的電子郵件最多可能需要15分鐘
才能到達您的收件箱。
1.首先為手機打造
客戶越來越多地移動,僅移動客戶的比例正在上升。但是,移動設備上的轉化率往往較低。在上述時尚零售商網站上工作的獨立網絡性能顧問Andy Davies表示,現在應該改變這一點,并最終將移動設備視為一流公民。
他解釋說:“響應式Web設計使我們能夠構建理論上可以在臺式機和移動臺上均能正常工作的網站。” “不幸的是,我們似乎經常經常先為臺式機設計和構建,然后嘗試縮小網站規模以適應移動設備的限制。這會導致緩慢,緩慢的移動體驗,尤其是對于使用Android的訪問者而言,他們的設備通常無法應付桌面上的JavaScript以及我們向他們提供的其他內容,因此使用它們的用戶尤其如此。
為了創建快速的移動優先體驗,Andy建議構建可在低成本Android手機(例如Alcatel 1x)上使用的網站,然后在運行時對其進行增強,以通過功能更強大的設備和更大的屏幕為訪問者提供更豐富的體驗。
您可能還會喜歡: 為下一個十億用戶設計。
2.停止使用轉盤和滑塊
旋轉木馬,幻燈片和滑塊聽起來像在紙上一個偉大的想法,但Shopify速度優化專家亞歷山大·林,首席執行官Rvere,這背后是Shopify應用Hyperspeed警告說,他們有兩個重大缺陷,我們需要讓我們的客戶知道的。
他警告說:“他們不會將訪問者轉化為客戶,并且會降低您的網站速度。” “ 尼爾森·諾曼集團(Nielsen Norman Group)進行的可用性測試發現,訪客實際上忽略了輪播。更可惡的是,在圣母大學網站上進行的一項測試發現,只有百分之一的訪客點擊了第一張幻燈片。其余幻燈片的點擊次數甚至更少。”
輪播不僅吸引轉化,還使網站陷入困境。亞歷山大警告說,精美的滑塊需要額外的JavaScript,并且通常由幾張大圖像組成。
他建議說:“擺脫圓盤傳送帶,可以使頁面加載快得多,因為總頁面大小將大大減少。” “考慮一個擺放位置很好的英雄形象,用引人注目的號召性用語而不是輪播。它的加載速度更快,并且您將吸引更多的訪問者點擊您希望他們點擊的內容。”
網站性能:靜態主頁英雄
靜態首頁英雄圖片,帶有清晰的號召性用語。
3.優化圖像
圖像是任何電子商務商店中必不可少的一部分,它們通常構成了其中的大部分。但是,大圖片可能會使網站慢下來,因為大頁面的加載時間更長。
如果您或您的客戶希望保留所有圖像,Alexander Lam建議至少壓縮它們。
他建議:“在將任何圖像上傳到商店之前,請先通過tinyjpg.com或shortpixel.com之類的免費圖像壓縮器運行該圖像。” 這些服務將使您的圖像在數據大小方面變小,而不會犧牲質量或更改其實際尺寸。原始圖像通??梢钥s小70%以上,而不會出現明顯的質量變化。”
確保您使用正確的文件格式也很重要。如果您想要圖片中的透明像素,PNG圖像確實很有用,但是它們通常比JPEG占用更多的空間。
“如果您的PNG沒有透明像素,請在上傳之前考慮將其轉換為JPEG,” Alexander建議。“使用Photoshop或PNG2JPG之類的服務來更改文件格式。”
Web性能:原始文件,帶壓縮的JPEG,gif
將原始JPEG與壓縮版本進行比較,質量損失為70%。
4.延遲加載圖像
幫助企業保持客戶在線帳戶安全的創業公司Castle的會議發言人和軟件工程師Anna Migas同意,圖像是網絡性能的大罪魁禍首之一。
她警告說:“一張圖片可以說一千多個單詞,但加載可能還需要一千毫秒或更長的時間,更糟糕的是,延遲加載其他內容。” “想象一下,如果您的網站上有20張圖片并且它們都爭相下載,那會發生什么!”
Anna解釋說,做法是默認情況下不下載頁面上的所有圖像,而是使用一種稱為延遲加載的技術。這意味著最初只從頁面頂部提供圖像,然后在用戶向下滾動并靠近頁面上可以找到更多圖像的位置時開始獲取其余圖像。
“ 惰性加載通常是使用JavaScript完成的,您可以找到許多小型庫來幫助您達到這種效果,”安娜建議。“我個人最喜歡的是LazyLoad和yall.js。在Chrome瀏覽器中,可以通過將loading=“lazy”屬性添加到
標簽來使用本地函數來延遲加載所選圖像,但是對于其他瀏覽器來說,這不能解決問題。”
您可能還會喜歡: 延遲加載如何優化Shopify主題圖像。
5.通過字體交換加載網絡字體
不可否認,圖像是電子商務網站上銷售計劃的重要組成部分,但用戶也希望快速查看價格和產品說明。這就是為什么使文本盡可能快地可見至關重要的原因,但是由于Web字體的原因,它的加載速度并不總是足夠快。
“用戶看不到文本的一個原因是使用了默認情況下用戶計算機不支持的外部字體,”安娜·米加斯(Anna Migas)解釋說。“在那種情況下,網站需要先下載字體,然后才能在屏幕上顯示它們。有時可能要花一些時間,最好提供一種備用字體,該字體將立即顯示,然后換成所需的字體。”
為此,安娜建議,您可以font-display: swap在@ font-face聲明中添加屬性,或者,如果使用的是Google字體,則可以添加&display=swapURL參數(例如:)。
可以在Chris Coyier的CSS-Tricks文章中找到更多詳細信息(請注意,它是在可能使用URL參數選項之前編寫的)。
Web性能:加載和不加載字體交換
一個沒有(左)和有(右)字體交換的字體加載示例(來源:www.zachleat.com/foitfout/)。
6.創建流暢的動畫
只要做得好,動畫就可以無縫,巧妙地改善網站上的用戶體驗。但是,如果做錯了,他們可能會使您的訪客感到困惑和分散注意力。
目前在Netflix任職的高級軟件工程師Tyler Childs建議了一些技巧,以改善使用CSS或JavaScript創建的網絡動畫。
的CSS
泰勒解釋說:“固定平滑的CSS動畫有一個小秘密,那就是使用不會強制更改布局或重新繪制像素的屬性。” “經驗法則是只使用opacityand transform,但是如果您想更深入一點,請查看CSS觸發器。”
不透明度和變換都只會影響其樣式的內容。樣式化的內容可以有效地保留在頁面其余部分的適當位置,但是正如Tyler所展示的,對用戶而言,魔術將會發生:
其它屬性,如padding,margin,width,height,top,bottom,left,和right將迫使你的布局變化,這淌下來的所有內容,并可能導致顛簸或回流。
所有CSS屬性都可以用于布局,但是在設置內容動畫時要小心。
的JavaScript
泰勒(Tyler)警告說,JavaScript動畫非常棘手,因為它們與您網頁上的所有其他JavaScript共享相同的資源集。
requestAnimationFrame他建議:“ 使用JavaScript平滑動畫的秘訣是一種稱為的方法。” “如果正確完成,采用這種方法的動畫可以達到60 FPS!”
實際的用例requestAnimationFrame包括限制用戶交互,例如滾動或拖動事件。這些事件每秒可能觸發多次,這就是為什么對它們進行反彈以控制觸發次數是一種非常常見的方法。
許多去抖動實現的缺點是,它們沒有針對動畫或對DOM的任何更改進行優化。requestAnimationFrame最好使用的瀏覽器作為去抖動功能,因為它已針對動畫進行了優化。
requestAnimationFrame泰勒建議:“下一次您要限制某個事件時,請考慮嘗試一下防抖功能。” “最后一個好處是,requestAnimationFrame當不使用網頁時,通過暫停回調,將使用更少的系統資源。”
您可能還會喜歡: 具有CSS變量的UI動畫。
7.最小化第三方影響
隨著電子商務創新步伐的不斷提高,企業根本無法內部構建所有內容,因此自然而然地,我們依靠越來越多的第三方服務來支持我們。
網絡性能專家Ryan Townsend警告說,這些服務中的許多服務都集中在使用戶更容易上手,而不是實現的質量上,因此,性能通常因此受到損害。
他建議:“我的第一個建議是盡可能避免使用關鍵渲染路徑。” “確保您的網站快速繪制可以大程度地減少那些來之不易的訪問者的跳出率,因此請注意標記中從第三方加載的任何同步腳本,樣式表或字體。即使您只進行了很小的更改,也可能會產生巨大的影響-我的一位客戶只需將單個腳本標簽更改為異步即可將其在3G連接上的首次有意義的繪制時間減少了三分之一!”
解決涂裝時間只是解決性能問題的第一步。另一個是JavaScript執行,Ryan稱這是當今網絡的巨大瓶頸。他建議:
“我的提示是考慮何時需要第三方腳本來下載和執行。” “我的另一位客戶通過在訪問者擴展產品頁面上的評論選項卡時加載其顧客評論服務,而不是在每個頁面上均加載,從而在阻止低端移動設備上執行CPU方面節省了40%的費用。”
Ryan建議,這種技術通常適用于實時聊天,而不是在每個頁面上都彈出它,而是考慮在產品說明或常見問題解答中提供一個按鈕,以在訪問者表示愿意聊天時加載該按鈕。
Web性能:單個腳本加載的積極影響
將單個腳本從頁面加載期間的加載移動到用戶操作的積極影響。
8.預連接到關鍵的第三方域
獨立的網絡性能顧問Andy Davies指出,瀏覽器在發現和下載內容方面做得很出色,其順序使我們的頁面更??快,但是有時它們需要一點幫助。
他解釋說:“有些資源發現得較晚。” “字體和背景圖片僅在瀏覽器開始將樣式應用于頁面時才發現,其他資源可能依賴腳本來插入它們,例如Google Analytics(分析)或標簽管理器。如果這些資源來自第三方域,則在建立和保護新連接時會存在延遲。”
Andy建議使用Preconnect Resource Hint,它可以通過建議瀏覽器預熱到第三方域的新連接來幫助克服此延遲。
例如,如果資源托管在example.com上:
crossorigin如果要從example.com提取字體,則需要添加該屬性:
單個預連接有時可能會有很大的不同,但是Andy建議您可能需要嘗試一下,看看哪種方法最適合您的站點。
您可能還會喜歡: 通過縮小來提高商店加載時間的5種方法。
9.糾纏您的應用
使用Shopify主題時,第三方應用程序也會產生重大影響。Shopify Plus合作伙伴機構Disco的創始人兼首席執行官Gavin Ballard提醒說,無論您花費多少時間和精力來優化主題,都可以在Shopify App Store上的五分鐘內完成所有操作。
他解釋說:“可用的各種第三方應用程序是Shopify的優勢之一,但許多應用程序開發人員并沒有想到主題性能,甚至那些必須構建其應用程序才能與1,000,000 +跨Shopify平臺的電子商務商店,而不僅僅是您客戶的商店。”
為了大限度地降低對Shopify商店的性能影響,Gavin建議采取幾個步驟。
您需要一個應用程序嗎?
首先,首先考慮您是否真正需要一個應用程序。
加文指出:“許多Shopify應用商店應用程序都是為那些不具備HTML / CSS / JavaScript技能的商人而設計的,他們只需要一鍵安裝即可解決他們的需求。” “倒數計時器,公告欄或退出意圖彈出窗口之類的東西都可以僅使用少量Liquid,CSS和JavaScript 內置到主題中。直接在主題中構建這些功能可以使您更好地控制性能影響(例如,避免加載jQuery的 30個版本),并允許您應用此處和Web上其他地方討論的其他技術來優化代碼的交付。瀏覽器。”
該應用程序可以控制您嗎?
其次,如果您確定確實需要支持其所需功能的應用程序,請調查該應用程序是否可以控制它與主題的交互方式。
“ 例如,流行的Back in Stock應用程序使客戶能夠在產品重新入庫時通過電子郵件和SMS注冊通知通知的功能,而僅靠主題一個主題是無法實現的,” Gavin解釋道。“但是,它為前端開發人員提供了一系列選擇,包括如何將其功能集成到Shopify主題中-通過自動安裝程序,通過復制和粘貼的Liquid代碼段,或者通過使用JavaScript構建完全自定義的集成API。”
Web性能:Javascript文檔
Back in Stock應用程序的Javascript API文檔。
在一些實際案例中,Gavin能夠將Back In Stock應用程序集成到主題的產品頁面中,而對初始頁面大小或客戶加載時間沒有明顯影響。如果變體缺貨,他只是在產品頁面上渲染了一個“通知我”按鈕,而不是一個“添加到購物車”按鈕,然后,一旦頁面變了,就異步地將Back in Stock JavaScript庫和一些粘合代碼一起加載了。呈現給用戶。
“如果應用程序的開發人員不提供這類集成選項,可能值得與他們聯系,看看他們是否可以做任何事情,” Gavin建議。“至少,它將幫助提醒應用程序開發人員性能是其客戶商店的重要組成部分!”
您可能還會喜歡: 業內人士對Shopify所采用技術的關注。
10.監視每個子域的請求數
自Honeycomb.io工程總監Emily Nakashima于2000年代初開始為網絡編寫代碼以來,瀏覽器的發展便突飛猛進,但是對于我們仍然需要支持HTTP 1.1的我們來說,一件事并沒有已更改-瀏覽器對任何一個子域(通常是六個)發出的并發請求數量仍然存在限制。
“這個限制的目的是防止當您嘗試一次加載整個圖像目錄頁面或其他資源時,意外地在某個小型Web服務器上發起DOS攻擊,” Emily解釋說。“但是在當今的網絡上,我們許多人使用高度可擴展的云服務并通過CDN提供圖像,因此限制可能不必要地減慢了您的體驗。”
要解決此問題,Emily建議使用一種稱為域分片的技術,該技術從多個域或子域中加載一組資源,以增加并發請求的數量。例如,您可能將多個子域(cdn1.example.com,cdn2.example.com等)與同一個CDN一起使用,以便能夠一次加載更多圖像。但是使用多個域會產生一些開銷,您需要為每個新域提出另一個DNS請求,然后才能開始下載我們的資源。
如果您想知道是否配置了我們的域分片,或者是否應該添加更多內容,請分析每個域的并發請求數。
“當您在瀏覽器開發人員工具中查看客戶端分布式跟蹤或瀏覽器的網絡瀑布時,請查看請求的模式,” Emily建議。“如果瀑布相對狹窄,并且請求大多同時發生,那么您可能有足夠的碎片。如果您以階梯狀模式看到到同一域的順序請求塊,則可能應該配置更多的分片。”
下圖中的圖1顯示了一個向單個域發出請求的網站-您可以看到許多階梯式的順序請求。另一方面,圖2演示了在向許多不同的域發出請求時,可以實現更高的并發性(在這種情況下,x軸被放大,因此各個跨度顯得更寬)。
Web性能:對單個域還是多個域的請求
“我們希望能夠在發生此類問題時獲得自動警報,” Emily解釋說,“因此,我們使用Resource Timing API來收集加載在特定頁面上的子資源的列表,并在總數達到請求或對特定子域的請求超過了一定數量。”
11.使用績效預算
對于許多開發人員來說,性能優化是目前最有趣的工程工作類型之一,因此很容易陷入困境,花幾天時間優化緩慢的東西,即使這對他們的客戶來說可能并不那么重要。因此,艾米莉·中島(Emily Nakashima)建議確保您正在優化真正重要的事情。
她透露:“在Honeycomb,我們非常樂于采用“服務水平目標(SLO)”方法來防止兔眼優化。” “使用SLO時,您會根據客戶的期望和容忍度提前設置目標,以提高網站的性能和可靠性(例如,'我的客戶整天使用我們的網站,因此他們需要它感覺敏捷-主頁請求應在一秒鐘內完成”)。
“您還為超出目標的頻率設置了預算(例如,'主頁請求的第95個百分位延遲應少于一秒鐘,即99.9%的時間”)。當您的預算超出預算時,這就是您要花時間優化使預算不足的事情的信號,因此您可以確保自己正在研究客戶最關心的問題。在剩下的時間里,您會對進行非性能工作感到滿意,例如投資新功能或清理技術債務。”
Emily指出,在網絡性能世界中,性能預算是一種特殊的SLO類型,旨在確保您的網站快速加載。有很多很棒的工具使跟蹤性能預算比跟蹤平均SLO更容易。
在Honeycomb,Emily使用實時開發人員工具幫助軟件工程師了解生產系統中發生的事情,該團隊通過跟蹤生產中的頁面加載時間來衡量其性能預算。但是,對于不大量使用實時用戶監控(RUM)數據的團隊,Emily說,跟蹤和執行性能預算的最簡單方法是將其內置到其構建工具(例如webpack)中并確保HTML,CSS和JavaScript限于一定的文件大小和文件數。
查看Google的Lighthouse審核工具和MDN網絡文檔,它們都對如何設置自己的效果預算有很好的建議。
通過Shopify合作伙伴計劃發展您的業務
無論您提供市場營銷,定制服務還是
網站設計和開發服務,Shopify合作伙伴計劃都將助您成功。免費加入并獲得收益共享的機會,發展業務的工具以及充滿激情的商業社區。
放在一起
正如我們專家的提示所顯示,圖像和第三方服務仍然是網站運行緩慢的主要原因之一。在圖像優化上投入時間和資源,并大程度地減少第三方影響,并且很有可能對正在工作的網站的性能產生重大影響。此外,拋開輪播并優化字體和動畫,您將節省更多的時間。
將其與移動優先方法和性能預算相結合,您將擁有一個可靠的Web性能策略,其結果將使您的客戶和他們的客戶都滿意?,F在加快該網站的速度!
網站欄目:如何大幅提升網站建設完成后打開的速度
文章源于:http://vcdvsql.cn/news43/174093.html
成都網站建設公司_創新互聯,為您提供網站維護、域名注冊、網站建設、網站設計、企業建站、外貿網站建設
廣告
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源:
創新互聯