Vue預渲染prerender-spa-plugin+vue-meta-info

前言

vue屬于單頁面應用修然,對于SEO不太友好非区,當然vue也給出了相應的解決辦法郭膛,可以通過vue ssr服務端渲染進行解決麸拄,但對于頁面較少的企業(yè)站來說可以直接使用 prerender-spa-plgin惜索,本文總結(jié)prerender-spa-plugin+vue-meta-info做seo優(yōu)化及遇到的問題特笋。

一、prerender-spa-plugin使用

vue版本2.6.12
webpack4.0

1.安裝

//npm 
npm install prerender-spa-plugin --save
//yarn
yarn add prerender-spa-plugin --dev

2.vue.config.js配置


const PrerenderSPAPlugin = require('prerender-spa-plugin');
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer;
const path = require('path');
function resolve(dir) {
    return path.join(__dirname, dir)
}
module.exports = {
    //配置絕對路徑
    publicPath: '/',
    outputDir: 'dist',
    assetsDir: 'static',
    configureWebpack: config=> {
    //在開發(fā)環(huán)境不進行預渲染操作
    if(process.env.NODE_ENV === 'production'){
           const plugins=[
                new PrerenderSPAPlugin({
                    //根目錄
                    staticDir: resolve('dist'),
                    //需要預渲染的路由
                    routes:['/','/about','/contact'],
                    renderer: new Renderer({
                      ignoreJSErrors: true,
                      inject: {
                        foo: 'bar'
                      },
                      //渲染時顯示瀏覽器窗口,建議直接為true
                      headless: true,
                      //最大渲染路由數(shù)量
                      maxConcurrentRoutes:20,
                      //延遲多長時間進行渲染
                      renderAfterTime: 5000,
                      //main.js中進行對應配置
                      renderAfterDocumentEvent: 'render-event'
                    })
                })
            ]
            config.plugins.push(...plugin)
        }
    }
}

3.main.js配置

new Vue({
    el: '#app',
    store,
    router,
    render: h => h(App),
    //重要部分
    mounted () {
      document.dispatchEvent(new Event('render-event'))
     }
})

4.router.js中一定要設置history模式

export default new Router({
    mode: 'history', // 路由模式
    routes: constantRoutes,
})

5.npm run build
打包之后可以看到配置好的路由生成了相應的html頁面

269b23c7c40644e386393c1c5fe8f1b5.jpeg

二巾兆、vue-meta-info使用

1.安裝

npm install vue-meta-info --save

2.main.js引用

import MetaInfo from 'vue-meta-info'
// 注冊 
Vue.use(MetaInfo)

3.頁面使用

//單個頁面配置
<template>
    <div>首頁</div>
</template>
export default {
    name:'首頁'
    metaInfo:{
        title:'首頁',
        meta:[
            {
                name: 'keyWords',
                content:'關(guān)鍵字'
            },
            {
                name:'description',
                content:'描述'
            }
        ]
    }
}
//多頁面配置
<template>
    <div>首頁</div>
</template>
export default {
    name:'index'
    metaInfo():{
        return{
            meta:this.metaData
        }
    },
    data(){
        return{
            metaData:''
        }
    },
    watch:{
        $route(to,form){
        //通過跳轉(zhuǎn)頁面配置每個頁面的關(guān)鍵字和描述猎物,這只是個例子
        //注意如果通過to.path去判斷 需要進行兼容判斷 因為渲染后的訪問路徑會在末尾自動添加/ 例如 loclhost:3000/index/,這個時候就需要 to.path === '/index' || to.path==='/index/'
            if(to.name === 'index'){
                this.metaData=[
                    {
                        name: 'keyWords',
                        content:'關(guān)鍵字'
                    },
                    {
                        name:'description',
                        content:'描述'
                    }
                ]
            }
            //當然也可以封裝一個方法去返回每個頁面的文案
            //this.metaData = metaSetFuc(to.name)
        }
    }
}

三、在使用中遇到的問題

1. [prerender-spa-plugin] Unable to prerender all routes! 錯誤
在node_modules -> @prerender -> renderer-puppeteer -> es6 -> renderer.js(113行)

await page.goto(`${baseURL}${route}`, navigationOptions);
//修改為
await page.goto(`${baseURL}${route}`, {...navigationOptions, timeout: 0});

2.修改完成之后一直處于build狀態(tài)打包并未成功
檢查一下index.html中是否存在引用外部css/js文件角塑,因為在打包過程中未能拉取外部文件內(nèi)容導致一直處于build狀態(tài)蔫磨,例如

<head>
    //這種形式引用思源黑體字體庫
    <link rel="stylesheet" >
</head>

3.假如項目中用到了swiper,也許會產(chǎn)生一個問題進行預渲染后圃伶,swiper-slide渲染了個默認800px的寬度堤如,導致刷新頁面輪播圖樣式顯示異常,暫時只能手動修改打包后的文件如果有解決辦法歡迎留言

使用webpack5可以看一下: prerender-spa-plugin-next

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末窒朋,一起剝皮案震驚了整個濱河市搀罢,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌侥猩,老刑警劉巖榔至,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異欺劳,居然都是意外死亡唧取,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進店門杰标,熙熙樓的掌柜王于貴愁眉苦臉地迎上來兵怯,“玉大人,你說我怎么就攤上這事腔剂∶角” “怎么了?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長袜漩。 經(jīng)常有香客問我绪爸,道長,這世上最難降的妖魔是什么宙攻? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任奠货,我火速辦了婚禮,結(jié)果婚禮上座掘,老公的妹妹穿的比我還像新娘递惋。我一直安慰自己,他們只是感情好溢陪,可當我...
    茶點故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布萍虽。 她就那樣靜靜地躺著,像睡著了一般形真。 火紅的嫁衣襯著肌膚如雪杉编。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天咆霜,我揣著相機與錄音邓馒,去河邊找鬼。 笑死蛾坯,一個胖子當著我的面吹牛光酣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播偿衰,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼挂疆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了下翎?” 一聲冷哼從身側(cè)響起缤言,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎视事,沒想到半個月后胆萧,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡俐东,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年跌穗,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片虏辫。...
    茶點故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡蚌吸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出砌庄,到底是詐尸還是另有隱情羹唠,我是刑警寧澤奕枢,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站佩微,受9級特大地震影響缝彬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜哺眯,卻給世界環(huán)境...
    茶點故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一谷浅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧奶卓,春花似錦一疯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瑟幕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間留潦,已是汗流浹背只盹。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留兔院,地道東北人殖卑。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像坊萝,于是被迫代替她去往敵國和親孵稽。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,947評論 2 355

推薦閱讀更多精彩內(nèi)容