


Wie rendere ich Webseiten in Vue vorab? Eine kurze Analyse der Verwendung des Prerender-Spa-Plugins
Wie rendere ich Webseiten in Vue vorab? In diesem Artikel erfahren Sie, wie Vue das Prerender-Spa-Plugin zum Vorrendern von Webseiten verwendet. Ich hoffe, es wird Ihnen hilfreich sein!
Vorrendern
Normalerweise ist das Vue-Projekt ein einseitiges Projekt, das heißt, das gerenderte Projekt hat nur eine index.html
. [Verwandte Empfehlung: vue.js Video-Tutorial] index.html
。【相关推荐:vue.js视频教程】
这样的缺点很明显:
- 部署到Nginx,需要做
try_files $uri $uri/ /index.html
内部重定向,才可以用通过路由访问页面。 - SEO不友好,搜索引擎收录效果不佳。
而预渲染,就是把原来的单index.html
,渲染成多个目录,每个目录又有一个index.html
。这样就不需要内部重定向访问路由,也更利于搜索引擎收录。
prerender-spa-plugin
本次预渲染使用prerender-spa-plugin进行预渲染。
它的主要原理是启动浏览器,渲染完成后抓取HTML,然后再创建目录,保存为index.html
。
注意:
- 官网目前只有Vue2.x的Demo,实际上是支持Vue3的(本次演示也是使用Vue3)
- 虽然最近的一个发布版本是2018年(最近应该会发布新版本),但是一直有维护,可以使用。
安装
首先,我们用npm进行安装:
npm i prerender-spa-plugin
需要注意,因为
prerender-spa-plugin
会安装一个Chromium,所以安装会比较久。
当然,这种依赖,只有在打包时候才使用。所以,更好的安装方式,应该是:
npm i prerender-spa-plugin -D
项目引用
现在,我们就来项目引用,使用方法很简单,方便在两个地方追加:
- App.vue
- vue.config.js
App.vue
首先,我们在App.vue
内追加触发器事件:
mounted() { document.dispatchEvent(new Event('render-event')) }
添加这个触发器,是后续打包时候,会自动触发,并完成渲染。
vue.config.js
根据prerender-spa-plugin
项目文档:
const path = require('path') const PrerenderSPAPlugin = require('prerender-spa-plugin') module.exports = { plugins: [ ... new PrerenderSPAPlugin({ // Required - The path to the webpack-outputted app to prerender. staticDir: path.join(__dirname, 'dist'), // Required - Routes to render. routes: [ '/', '/about', '/some/deep/nested/route' ], }) ] }
同时一些高级使用需要引入PuppeteerRenderer
进行自定义。所以,我自己的vue.config.js
配置:
module.exports = { …… chainWebpack: config => { if (process.env.NODE_ENV == "development") { …… } if (process.env.NODE_ENV == "production") { config.plugin("PrerenderSPAPlugin").use('prerender-spa-plugin', [ { staticDir: path.join(__dirname, 'dist'), routes: [ '/', '/processIMG', '/statisticsChars', '/generatePWD', '/calculateTheDate', '/randomNumber', '/textBase64', '/curl', '/mcstatus', '/gh', '/about', '/mdv' ], renderer: new PuppeteerRenderer({ headless: false, executablePath: '/Applications/Google Chrome.app/Contents/MacOS/Google Chrome', // 对应App.vue renderAfterDocumentEvent: 'render-event', }), }]) ]) } }
我使用的是链式函数。这样的好处,是方便我进行if-else
等函数式判断。
其中,renderer
属性:
-
headless
:这个就是Chrome的headless
属性,常用于Debug。更多可以参考:Google Chrome -
executablePath
:重定向浏览器地址;我这里重定向使用我电脑自带的Chrome浏览器了。(可选,可以直接不加,默认调用Chromium) -
renderAfterDocumentEvent
:需要同App.vue中 document.dispatchEvent(new Event('render-event'))的事件名称要对应上。
而routes
数组,里面就是需要预渲染的路由地址。
当然,更多的可选参数,你也可以参考官方的文档:
staticDir
- Zur Bereitstellung auf Nginx müssen Sie eine interne Umleitung
try_files $uri $uri/ /index.html
durchführen, bevor Sie über Routing auf die Seite zugreifen können.
- SEO ist nicht benutzerfreundlich und die Indexierungswirkung der Suchmaschinen ist nicht gut.
Und beim Vorrendern wird die ursprüngliche einzelne try_files $uri $uri/ /index.html
durchführen, bevor Sie über Routing auf die Seite zugreifen können. index.html
in mehrere Verzeichnisse gerendert, und jedes Verzeichnis verfügt über eine andere index.html
>. Dadurch entfällt die Notwendigkeit interner Umleitungszugriffsrouten und die Einbindung in Suchmaschinen wird besser unterstützt.

Dieses Vor-Rendering verwendet prerender-spa-plugin für das Vorrendern.
Sein Hauptprinzip besteht darin, den Browser zu starten, den HTML-Code nach Abschluss des Renderns abzurufen, dann ein Verzeichnis zu erstellen und es als index.html
zu speichern.
Hinweis:
- Auf der offiziellen Website gibt es derzeit nur eine Demoversion von Vue2 (eine neue Version sollte kürzlich veröffentlicht werden), diese wird jedoch immer gepflegt und kann verwendet werden.
npm run build
🎜 Es ist zu beachten, dass die Installation lange dauern wird, da prerender-spa-plugin
ein Chromium installiert. 🎜
🎜
# 删除项目node_modules rm -rf node_modules # 重新安装 npm install🎜Projektreferenz🎜🎜Kommen wir nun zur Projektreferenz. Die Verwendungsmethode ist sehr einfach und es ist praktisch, sie an zwei Stellen anzuhängen: 🎜
- App.vue li>
- vue.config.js
App.vue
hinzu: 🎜location / { try_files $uri $uri/ /index.html; }🎜Fügen Sie diesen Trigger hinzu, der beim nachfolgenden Packen und Rendern automatisch ausgelöst wird. 🎜🎜vue.config.js🎜🎜Gemäß der
prerender-spa-plugin
-Projektdokumentation : 🎜 config.devServer.proxy({ '/dataApiJava': { target: JavaBaseURL, pathRewrite: {'^/dataApiJava': ""}, ws: true, changeOrigin: true }, '/dataApiPython': { target: PythonBaseURL, pathRewrite: {'^/dataApiPython': ""}, ws: true, changeOrigin: true }, '/ghs': { target: GithubSpeedURL, pathRewrite: {'^/ghs': ""}, ws: true, changeOrigin: true } } )🎜Gleichzeitig müssen einige erweiterte Anwendungen zur Anpassung
PuppeteerRenderer
einführen. Also meine eigene vue.config.js
-Konfiguration: 🎜location /dataApiPython/{ proxy_pass http://127.0.0.1:8099/; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; add_header X-Cache $upstream_cache_status; } location /dataApiJava/ { proxy_ssl_server_name on; proxy_pass https://…….cn/; } location /ghs/ { proxy_ssl_server_name on; proxy_pass https://……/gh/; }🎜Ich verwende Kettenfunktionen. Dies hat den Vorteil, dass es mir leichter fällt, funktionale Urteile wie
if-else
zu fällen.
Darunter das renderer
-Attribut: 🎜-
headless
: Dies ist dasheadless
-Attribut von Chrome, das häufig zum Debuggen verwendet wird. Weitere Informationen finden Sie unter: Google Chrome -
executablePath
: Umleitungsbrowseradresse; Ich verwende hier den Chrome-Browser, der mit meinem Computer geliefert wird. (Optional, Sie können es nicht direkt hinzufügen, Chromium wird standardmäßig aufgerufen) -
renderAfterDocumentEvent
: Muss dasselbe sein wie document.dispatchEvent(new Event('render-event ')) in App.vue Die Ereignisnamen sollten übereinstimmen.
routes
enthält die Routing-Adressen, die vorgerendert werden müssen. 🎜🎜
staticDir
muss auf den kompilierten Ausgabeordner verweisen. 🎜🎜Nach dem Packen des Projekts🎜🎜 können wir das Projekt verpacken: 🎜rrreee🎜Der Effekt nach dem Packen: 🎜🎜🎜🎜🎜Sehen Sie sich die vorgerenderte Seite an: 🎜🎜🎜🎜🎜Weil ich Komponenten habe, die Vue-Meta verwenden, Daher verfügen vorgerenderte Dateien auch über Metaattribute. 🎜如果你也想用Vue-meta组件配合
prerender-spa-plugin
,可以参考文章:https://juejin.cn/post/7056972997894094861
需要注意,如果出现什么错误,可以尝试:
# 删除项目node_modules rm -rf node_modules # 重新安装 npm install
这样的文件,就可以进行部署了。
部署效果
我们使用Nginx进行部署,上次到Nginx Web文件夹内,修改config
文件,就不需要:
location / { try_files $uri $uri/ /index.html; }
来实现内部重定向了。因为有真实的目录,可以去掉。
但是,数据代理,最好使用Nginx来实现。比如,开发环境,数据代理:
config.devServer.proxy({ '/dataApiJava': { target: JavaBaseURL, pathRewrite: {'^/dataApiJava': ""}, ws: true, changeOrigin: true }, '/dataApiPython': { target: PythonBaseURL, pathRewrite: {'^/dataApiPython': ""}, ws: true, changeOrigin: true }, '/ghs': { target: GithubSpeedURL, pathRewrite: {'^/ghs': ""}, ws: true, changeOrigin: true } } )
对应的Nginx配置,可以这样写:
location /dataApiPython/{ proxy_pass http://127.0.0.1:8099/; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; add_header X-Cache $upstream_cache_status; } location /dataApiJava/ { proxy_ssl_server_name on; proxy_pass https://…….cn/; } location /ghs/ { proxy_ssl_server_name on; proxy_pass https://……/gh/; }
给大家展示三种配置,按需设置哦。
END
到此,我们的前端预渲染就完成了。这样SEO好。但是对比SSR,还是优点欠缺。好处就是部署和配置方便,坏处就是构建麻烦,如果你页面有几十个路由需要预渲染,那么prerender-spa-plugin渲染起来就没SSR方便了。
改天有机会和大家分享分享SSR吧,真不错,又挖一个坑。
另外,是不是有小伙伴好奇,我截图里出现的CompressionPlugin
属性?其实是gz压缩啦。有机会和大家分享,使用compression-webpack-plugin
来优化项目。
更多编程相关知识,请访问:编程入门!!
Das obige ist der detaillierte Inhalt vonWie rendere ich Webseiten in Vue vorab? Eine kurze Analyse der Verwendung des Prerender-Spa-Plugins. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Gründe für die Beliebtheit von Vue.js sind Einfachheit und einfaches Lernen, Flexibilität und hohe Leistung. 1) Das progressive Framework -Design eignet sich für Anfänger, um Schritt für Schritt zu lernen. 2) Komponentenbasierte Entwicklung verbessert die Effizienz der Code-Wartbarkeit und der Teamkollaboration. 3) Responsive Systems und virtuelles DOM verbessern die Rendering -Leistung.

Vue.js ist einfacher zu bedienen und hat eine reibungslose Lernkurve, die für Anfänger geeignet ist. React hat eine steilere Lernkurve, hat jedoch eine starke Flexibilität, die für erfahrene Entwickler geeignet ist. 1.Vue.js ist einfach mit einfachen Datenbindung und progressivem Design zu beginnen. 2.React erfordert das Verständnis von virtuellem DOM und JSX, bietet jedoch höhere Flexibilität und Leistungsvorteile.

Vue.js eignet sich für schnelle Entwicklung und kleine Projekte, während React eher für große und komplexe Projekte geeignet ist. 1.Vue.js ist einfach und leicht zu lernen, geeignet für schnelle Entwicklung und kleine Projekte. 2.React ist leistungsstark und für große und komplexe Projekte geeignet. 3.. 4. Reacts komponentiertes und virtuelles DOM funktioniert gut, wenn es sich um komplexe Benutzeroberflächen- und datenintensive Anwendungen handelt.

Vue.js und reagieren jeweils ihre eigenen Vor- und Nachteile. Bei der Auswahl müssen Sie Teamfähigkeiten, Projektgröße und Leistungsanforderungen umfassend berücksichtigen. 1) Vue.js eignet sich für schnelle Entwicklung und kleine Projekte mit einer niedrigen Lernkurve, aber tiefe verschachtelte Objekte können Leistungsprobleme verursachen. 2) React ist für große und komplexe Anwendungen mit einem reichhaltigen Ökosystem geeignet, aber häufige Aktualisierungen können zu Leistungs Engpässen führen.

Vue.js eignet sich für kleine bis mittelgroße Projekte, während React für große Projekte und komplexe Anwendungsszenarien geeignet ist. 1) Vue.js ist einfach zu bedienen und ist für schnelle Prototypen und kleine Anwendungen geeignet. 2) React hat mehr Vorteile beim Umgang mit komplexem Zustandsmanagement und Leistungsoptimierung und ist für große Projekte geeignet.

Vue.js und React haben jeweils eigene Vorteile: Vue.js ist für kleine Anwendungen und schnelle Entwicklung geeignet, während React für große Anwendungen und komplexes Staatsmanagement geeignet ist. 1.Vue.js realisiert automatisches Update über ein reaktionsschnelles System, das für kleine Anwendungen geeignet ist. 2.React verwendet virtuelle DOM- und Diff -Algorithmen, die für große und komplexe Anwendungen geeignet sind. Bei der Auswahl eines Frameworks müssen Sie Projektanforderungen und Teamtechnologie -Stack in Betracht ziehen.

Vue.js und React jeweils haben ihre eigenen Vorteile, und die Auswahl sollte auf Projektanforderungen und Teamtechnologie -Stack beruhen. 1. Vue.js ist gemeinschaftsfreundlich und bietet reichhaltige Lernressourcen an, und das Ökosystem umfasst offizielle Tools wie Vuerouter, die vom offiziellen Team und der Community unterstützt werden. 2. Die React -Community ist in Bezug auf Unternehmensanwendungen mit einem starken Ökosystem voreingenommen und unterstützt von Facebook und seiner Community und hat häufige Aktualisierungen.

Netflix verwendet React, um die Benutzererfahrung zu verbessern. 1) Die komponentierten Merkmale von React unterstützen die Netflix -Komplex -Benutzeroberfläche in überschaubare Module. 2) Virtual DOM optimiert UI -Updates und verbessert die Leistung. 3) Die Kombination von Redux und GraphQL verwaltet Netflix den Anwendungsstatus und den Datenfluss effizient.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft
