直接使用Vue 建立前端單頁應用,頁面原始碼時只有簡單的幾行html,這並不利於網站的SEO,這時候就需要服務端渲染,本篇文章主要介紹了詳解Vue基於Nuxt.js實現服務端渲染(SSR),具有一定的參考價值,有興趣的小伙伴們可以參考一下
直接使用Vue 構建前端單頁應用,頁面源碼時只有簡單的幾行html,這並不利於網站的SEO,這時候就需要服務端渲染
2016 年10 月25 日,zeit.co 背後的團隊對外發布了一個React 的服務端渲染應用框架Next.js
幾小時後,一個基於Vue.js 的服務端渲染應用框架應運而生,與Next.js 異曲同工,這就是Nuxt.js
##一、快速模板
在已經安裝了vue-cli 的前提下,可以快速建立一個nuxt 的專案範本vue init nuxt-community/starter-template MyProject其中MyProject是專案資料夾名稱,可自訂透過npm install (似乎用
yarn install 更順利) 安裝依賴之後,可以直接npm run dev 在開發環境啟動專案
預設啟動的位址為http://localhost:3000/,可以在package.json 中新增以下設定來修改主機連接埠號碼
#
"config": { "nuxt": { "host": "0.0.0.0", "port": "7788" } },開發完成後執行npm run build 打包程式碼,最後npm start 啟動服務
二、重要目錄
#產生的專案目錄如下都是nuxt 預設保留的,不可修改
#其中比價比較關鍵的目錄有三個:1. components 元件目錄
非頁面層級的元件,如header、footer 等公共元件
該目錄下的元件具有常規vue 元件的方法和特性,不會被nuxt.js 擴充特性#2. layouts 佈局目錄
<template> <p> <my-header></my-header> <nuxt/> <my-footer></my-footer> </p> </template>其中
3. pages 頁面目錄
router: { routes: [ { name: 'index', path: '/', component: 'pages/index.vue' }, { name: 'about', path: '/about', component: 'pages/about.vue' }, { name: 'classroom', path: '/classroom', component: 'pages/classroom.vue', children: [ { path: 'student', component: 'pages/classroom/student.vue', name: 'student' }, { //定义带参数的动态路由,需要创建对应的以下划线作为前缀的 Vue 文件或目录 path: ':id', component: 'pages/classroom/_id.vue', name: 'classroom-id' } ] } ] }此外,目錄下的vue 元件也具備一些 Nuxt.js 提供的特殊功能特性其中
asyncData 方法較常用,支援非同步資料處理
這個方法會在頁面元件 每次載入之前被調用,然後取得資料並返回給目前元件
asyncData ({ params, error }) { return axios.get(`api/posts/${params.id}`) .then((res) => { return { name: res.data.name} }) .catch((e) => { error({ statusCode: 404, message: 'not found' }) }) }asyncData 方法的第一個參數為上下文物件context,具體屬性可以查看這裡由於asyncData方法是在元件初始化前被呼叫的,所以在方法內是沒有辦法透過this 來引用元件的實例物件
三、使用插件
如果專案中還需要引入其他的第三方插件,可以直接在頁面中引入,這樣在打包的時候,會將插件打包到頁面對應的js 裡面但要是別的頁面也引入了同樣的插件,就會重複打包。如果沒有需要分頁打包的需求,這時候可以設定plugins以element-ui 為例,在安裝了element-ui 之後,在plugins 目錄下建立elementUI.js
build: { vendor: ['~/plugins/elementUI.js'] }, plugins: [ {src: '~/plugins/elementUI.js'}, ]
##這裡的plugins 屬性用來設定vue.js 插件,也就是
可以用Vue.user() 方法的插件預設只需要src 屬性,另外還可以設定ssr: false,讓檔案只在客戶端被打包引入
如果是像axios 這種第三方(不能use) 插件,只需要在plugins 目錄下建立axios.js
##
// axios.js import Vue from 'vue' import axios from 'axios' const service = axios.create({ baseURL: '/api' }) Vue.prototype.$ajax = axios export default service
#
然后在 build.vendor 中添加配置 (不需要配置 plugins)
build: { vendor: ['~/plugins/axios.js'] }
这样在打包的时候,就会把 axios 打包到 vendor.js 中
四、Vuex 状态树
如果在 store 目录下创建了 index.js,nuxt.js 会根据该目录下的文件创建 Vuex 状态树
// store/index.js import Vue from 'vue' import Vuex from 'vuex' import Axios from '~/plugins/axios.js'; Vue.use(Vuex) const store = () => new Vuex.Store({ state: { author: 'WiseWrong', info: '' }, mutations: { setInfo (state, val) { state.info = val } }, actions: { loadAboutMeInfo ({commit, state}) { return Axios.get(`/about`) .then(res => { console.log('ajax is success') console.log(res.data.info) commit('setInfo', res.data.info) }) .catch(err => { console.log('error') }) } } }) export default store
Nuxt.js 内置引用了 vuex 模块,不需要额外安装
上面的代码中,我在 actions 中写了一个 loadAboutMeInfo() 方法,用来请求 /api/about 接口
然后在 about.vue 页面中调用
// about.vue <template> <section class="container"> <p> <img src="/static/imghwm/default1.png" data-src="~/assets/about.png" class="lazy" alt=""> </p> <h1 id="store-state-info">{{$store.state.info}}</h1> </section> </template> <script> export default { fetch({ store }) { return store.dispatch('loadAboutMeInfo') }, name: 'about', data () { return {} } } </script>
成果演示:
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
以上是詳解Vue基於 Nuxt.js 實作服務端渲染的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

記事本++7.3.1
好用且免費的程式碼編輯器

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。