Ember.js & SEO - 測試搜尋引擎對JavaScript的剖析能力

Ember.js & SEO - 測試搜尋引擎對JavaScript的剖析能力

Ember.js & SEO

Google Webmaster Central Blog在今年五月宣布 ,Google 搜尋能夠執行網頁上的 Javascript (見Understanding web pages better)。而過去已知Crawler只會剖析網頁上的HTML Code,而不會(或少量)執行JavaScript。。又由於開發品質與速度的要求,使得Single Page Application (SPA) frameworks盛行(例如:Angular.js、Ember.js等),於是了解搜尋引擎是否能夠執行並解讀JavaScript與解讀的程度便成為網站開發的其中一項需求。

利用Ember.js製作測試案例

如果編號1頁面可被剖析,我們還有後續的劇本可以持續測試...

資料來源:Friendo 粉多任務

探討方向

主要實驗對象是Goole搜尋,附帶Facebook。

  • Indexing

    • Google Search

      • 搜尋編號1頁面的關鍵字 "Ember.js & SEO 九品芝麻官大會考"

        • 提交後無法馬上經由搜尋特定關鍵字搜尋到[編號1頁面]
        • 約一週後可經由搜尋特定關鍵字找到該頁面,如下圖。

      • 搜尋編號2頁面的關鍵字 "Ember.js & SEO 玉泉水果酒 - 愛呆丸快樂產生器!" 可在提交後馬上經由搜尋特定關鍵字找到編號2頁面

      • 由以上兩點可知,推測會執行這段JavaScript Code,因此但無法馬上Indexing經由執行JavaScript Code所帶入的資料,而必須過一段時間。
      • 看Crawler得到的結果 (資料來源:Google模擬器,擷取並轉譯,如下圖)

      Google模擬器,擷取並轉譯

    • Facebook Share
      • 由Facebook所提供的工具可知,無法執行這段JavaScript Code和Indexing經由執行JavaScript Code所帶入的資料。
      • 看Crawler得到的結果 or Original Result From Facebook
  • Linkability:由於無法Indexing,因此推測無Linkability(外部連結、Link Juice相關)。

結論

目前Google Search可剖析經由SPA帶入到頁面的資料但不即時,因此若想利用SPA來開發前台,必須思考網站是否有SEO的需求。若有,頁面重要資訊還是必須放在HTML上,或利用其他的解法(為Crawler另外提供一個頁面、Server Pre-renderingPhantomJS 等)。

相關實驗可見 SEO Strategies for JavaScript-Heavy Single Page Applications or AJAX Sites

就算使用SPA建構網站,還是可以在SERPs得到高的排名?

就排名來說,由於搜尋引擎的排名是由眾多因素集合起來的,因此若其他地方做得很好,也是可以有很好的搜尋排名。例如高品質的Inbound Links、網站效能佳、速度快、社群平台熱烈討論、On-Page SEO等。


參考資料

留言