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

詳解Vue開發(fā)網(wǎng)站seo優(yōu)化方法

 更新時間:2021年05月07日 14:21:44   作者:龖龖龖  
這篇文章主要介紹了Vue開發(fā)網(wǎng)站seo優(yōu)化方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

因為用了vue等js的數(shù)據(jù)綁定機制來展示頁面數(shù)據(jù),爬蟲獲取到的html是模型頁面而不是最終數(shù)據(jù)的渲染頁面,搜索引擎是不回去執(zhí)行請求到的js。vue的項目都是ajax請求數(shù)據(jù),引擎爬蟲進入頁面獲取不到文字內(nèi)容,現(xiàn)在大多數(shù)解決方案是不采用ajax渲染數(shù)據(jù),而是采用server端渲染,也就是所謂的SSR。
目前基于vue的方案是Nuxt.js,同類型的也有React版的Nuxt.js所以服務(wù)端渲染就是盡量在服務(wù)器發(fā)送到瀏覽器前,頁面上是有數(shù)據(jù)可讓爬蟲進行爬取

方法一、利用prerender-spa-plugin插件將單頁面應(yīng)用打包成多頁面

傳統(tǒng)的vue通過vue-cli腳手架搭建完成后要通過npm run build來打包生成最后的要放到線上的html代碼。
vue搭建的單頁面項目有各種優(yōu)點,易維護、代碼簡潔、開發(fā)體驗好等等。但是對于一些傳統(tǒng)的互聯(lián)網(wǎng)公司,vue單頁面卻有一個很致命的問題就是seo優(yōu)化的問題。下面是正常打包的vue單頁面目錄以及index.html的代碼。

在這里插入圖片描述

在這里插入圖片描述

目錄只有一個index.html文件并且這個html文件里面是沒有任何內(nèi)容的只有一個id為app的用來掛載vue實例的div。
谷歌搜索引擎已經(jīng)可以很好地支持單頁面的信息爬取,但是谷歌是國外的國內(nèi)使用要翻墻所以不作考慮,百度是國內(nèi)最主要的搜索引擎,百度并不能爬取單頁面的數(shù)據(jù)所以這樣的項目如果上線了別人在百度搜索的時候很難找到這個項目。由于我目前公司的大部分項目都是需要做seo優(yōu)化的所以這個問題就丟到了我這里。

解決辦法

這里先提一下如果打包的時候報錯可能你需要npm安裝一下puppeteer(這東西有點大大概300多M)

第一步通過prerender-spa-plugin來進行vue.config.js的配置

npm isntall prerender-spa-plugin --save

這個東西是vue用來將單頁面應(yīng)用打包成多頁面的第三方插件,安裝完成之后在vue.config.js配置配置如下

const PrerenderSPAPlugin = require('prerender-spa-plugin');
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer;
const webpack = require('webpack');
const path = require('path');
 
module.exports = {
    configureWebpack: config => {
        if (process.env.NODE_ENV !== 'production') return;
        return {
            plugins: [
                new PrerenderSPAPlugin({
                    // 生成文件的路徑,也可以與webpakc打包的一致。
                    // 下面這句話非常重要?。?!
                    // 這個目錄只能有一級,如果目錄層次大于一級,在生成的時候不會有任何錯誤提示,在預(yù)渲染的時候只會卡著不動。
                    staticDir: path.join(__dirname,'dist'),
                    // 對應(yīng)自己的路由文件,比如a有參數(shù),就需要寫成 /a/param1。
                    routes: ['/','/about','/store_vuex','/cssAnimate','/connectMongoDB','/childParent','/child1','/elementUI'],
                    // 這個很重要,如果沒有配置這段,也不會進行預(yù)編譯
                    renderer: new Renderer({
                        inject: {
                            foo: 'bar'
                        },
                        headless: false,
                        // 在 main.js 中 document.dispatchEvent(new Event('render-event')),兩者的事件名稱要對應(yīng)上。
                        renderAfterDocumentEvent: 'render-event'
                    })
                })
            ],
        };
    }
}

然后要將vue路由的模式改成history
最后mian.js入口文件中要加入這段代碼。其中render-event要和vue.config.js中的renderAfterDocumentEvent對應(yīng)

new Vue({
  router,
  store,
  render: h => h(App),
  mounted () {
    document.dispatchEvent(new Event('render-event'))
  }
}).$mount('#app')

npm run build現(xiàn)在打包之后的目錄結(jié)構(gòu)就變成了這樣了,以及每個文件夾的index.html代碼,
現(xiàn)在的html代碼就有了.vue文件中的template相關(guān)代碼,但是卻多了一個問題就是每個文件夾中的index.html代碼都引用了所有的js和css文件這是不利于seo優(yōu)化的。因此還沒有結(jié)束。

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

為什么會有這么多js和css呢,因為vue-cli在打包的時候每個.vue文件的script和style標簽都會打包成一個對應(yīng)的js和css,即使你標簽里面什么都沒有寫。

第二步我是壓縮合并體積比較小的js和css文件

找了vue-cli的文檔沒有搜索到相關(guān)的資料,因此轉(zhuǎn)戰(zhàn)webpack
這個api可以用來設(shè)定一個最小的合并文件體積,在上邊的webpack配置中的plugins中加入這段代碼目測是10000=1kb

const webpack = require('webpack');
 
new webpack.optimize.MinChunkSizePlugin({
                    minChunkSize: 10000 // 通過合并小于 minChunkSize 大小的 chunk,將 chunk 體積保持在指定大小限制以上
                }),

然后npm run build還是那個目錄,但是js和css縮減了很多。

在這里插入圖片描述

方法二、Vue SSR (服務(wù)器端渲染)

簡而言之就是將本來要放在瀏覽器執(zhí)行創(chuàng)建的組件,放到服務(wù)端先創(chuàng)建好,然后生成對應(yīng)的html將它們直接發(fā)送到瀏覽器,最后將這些靜態(tài)標記"激活"為客戶端上完全可交互的應(yīng)用程序。

Vue SSR 相比 SPA(單頁應(yīng)用)好處及壞處
1、好處
更好的 SEO,由于搜索引擎爬蟲抓取工具可以直接查看完全渲染的頁面。

更快的內(nèi)容到達時間(time-to-content),特別是對于緩慢的網(wǎng)絡(luò)情況或運行緩慢的設(shè)備。

2、壞處
1)開發(fā)條件所限。瀏覽器特定的代碼,只能在某些生命周期鉤子函數(shù)(lifecycle hook)中使用;一些外部擴展庫(external library)可能需要特殊處理,才能在服務(wù)器渲染應(yīng)用程序中運行。

2)涉及構(gòu)建設(shè)置和部署的更多要求。與可以部署在任何靜態(tài)文件服務(wù)器上的完全靜態(tài)單頁面應(yīng)用程序(SPA)不同,服務(wù)器渲染應(yīng)用程序,需要處于 Node.js server 運行環(huán)境。

3)更多的服務(wù)器端負載。在 Node.js 中渲染完整的應(yīng)用程序,顯然會比僅僅提供靜態(tài)文件的 server 更加大量占用 CPU 資源(CPU-intensive - CPU 密集),因此如果你預(yù)料在高流量環(huán)境(high traffic)下使用,請準備相應(yīng)的服務(wù)器負載,并明智地采用緩存策略。

到此這篇關(guān)于詳解Vue開發(fā)網(wǎng)站seo優(yōu)化方法的文章就介紹到這了,更多相關(guān)Vue seo優(yōu)化 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue編譯器AST抽象語法樹源碼分析

    Vue編譯器AST抽象語法樹源碼分析

    這篇文章主要為大家介紹了Vue編譯器AST抽象語法樹源碼分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Vue中的Ajax?配置代理slot插槽的方法詳解

    Vue中的Ajax?配置代理slot插槽的方法詳解

    這篇文章主要介紹了Vue中的Ajax?配置代理?slot插槽的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • vue實現(xiàn)用v-bind給src和href賦值

    vue實現(xiàn)用v-bind給src和href賦值

    這篇文章主要介紹了vue實現(xiàn)用v-bind給src和href賦值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue使用$emit實現(xiàn)同步調(diào)用

    vue使用$emit實現(xiàn)同步調(diào)用

    這篇文章主要介紹了vue使用$emit實現(xiàn)同步調(diào)用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue3關(guān)于RouterView插槽和過渡動效

    vue3關(guān)于RouterView插槽和過渡動效

    這篇文章主要介紹了vue3關(guān)于RouterView插槽和過渡動效,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 解決vue-cli創(chuàng)建項目的loader問題

    解決vue-cli創(chuàng)建項目的loader問題

    下面小編就為大家分享一篇解決vue-cli創(chuàng)建項目的loader問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看看吧
    2018-03-03
  • Vue中addEventListener()?監(jiān)聽事件案例講解

    Vue中addEventListener()?監(jiān)聽事件案例講解

    這篇文章主要介紹了Vue中addEventListener()?監(jiān)聽事件案例講解,包括語法講解和事件冒泡或事件捕獲的相關(guān)知識,本文結(jié)合示例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2022-12-12
  • vue3?關(guān)于reactive的重置問題及解決

    vue3?關(guān)于reactive的重置問題及解決

    這篇文章主要介紹了vue3?關(guān)于reactive的重置問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 關(guān)于vue組件事件屬性穿透詳解

    關(guān)于vue組件事件屬性穿透詳解

    今天小編就為大家分享一篇關(guān)于vue組件事件屬性穿透詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue中使用fetch讀取本地txt文件的技術(shù)實現(xiàn)

    Vue中使用fetch讀取本地txt文件的技術(shù)實現(xiàn)

    在Vue.js應(yīng)用開發(fā)中,有時我們需要從本地讀取文本文件(如 .txt 文件)并將其內(nèi)容展示在頁面上,這種需求在處理配置文件、日志文件或靜態(tài)數(shù)據(jù)時非常常見,本文將詳細介紹如何在Vue中使用 fetch API 讀取本地 .txt 文件,并提供多個示例和使用技巧
    2024-10-10

最新評論