Vue+Nuxt.js makes server-side rendering

php中世界最好的语言
Release: 2018-06-11 09:51:25
Original
3171 people have browsed it

This time I will bring you Vue Nuxt.js to make server-side rendering. What are the precautions for Vue Nuxt.js to make server-side rendering? The following is a practical case, let’s take a look.

1. Quick template

On the premise that vue-cli has been installed, you can quickly create a nuxt project template

vue init nuxt-community/starter-template MyProject
Copy after login

where MyProject is the name of the project folder, which can be customized

Through npm install (it seems to be smoother withyarn install) After installing the dependencies, you can directly npm run dev inDevelopment environmentStart the project

The default startup address is http://localhost:3000/, you can add the following configuration inpackage.jsonto modify the host port number

"config": { "nuxt": { "host": "0.0.0.0", "port": "7788" } },
Copy after login

After the development is completed, execute npm run build to package the code, and finally npm start to start the service

2. Important directories

generated The project directory is as follows

Most folder namesare reserved by nuxt by default and cannot be modified

The directories that are more critical for price comparison There are three:

1. components component directory

is generally used to storenon-page levelcomponents , such as header, footer and other public components

The components in this directory have the methods and characteristics of regular vue components and will not be extended by nuxt.js

2. layouts layout directory

You can modify default.vue in this directory to modify the default layout

Copy after login

where is required, the page The main content will be displayed here (similar to the of the root node)

In addition, you can also add error.vue as an error page in the directory. For specific writing methods, please refer to the official documentation.

3. pages page directory

is used to store page-level components. nuxt will generate it based on the page structure in this directory. Routing

For example, the page structure in the picture above will generate such routing configuration:

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' } ] } ] }
Copy after login

In addition, the vue components in this directory also have some special features provided by Nuxt.js

Among them, theasyncDatamethod is more commonly used and supports asynchronous data processing.

This method will be called before each load of thepage component, and then obtains the data and returns it. For the current component

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' }) }) }
Copy after login

The first parameter of the asyncData method is the context object context. The specific properties can be viewed here

Since the asyncData method is called before the component is initialized, so within the method is There is no way to reference the instance object of the component through this

3. Use plug-ins

If you need to introduce other third-party plug-ins into the project, It can be introduced directly into the page, so that when packaging, the plug-in will be packaged into the js corresponding to the page

But if the same plug-in is also introduced in other pages, it will be packaged repeatedly. If there is no need for paging packaging, you can configure plugins at this time

Take element-ui as an example. After installing element-ui, create elementUI.js in the plugins directory

Then add the configuration items build.vendor and plugins in nuxt.config.js in the root directory

build: { vendor: ['~/plugins/elementUI.js'] }, plugins: [ {src: '~/plugins/elementUI.js'}, ]
Copy after login

The plugins property here is used to configure the vue.js plug-in, which isYou can use the Vue.user() methodof the plug-in

which only requires the src attribute by default. You can also configure ssr: false so that the file is only packaged and imported on the client

如果是像 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
Copy after login

然后在 build.vendor 中添加配置(不需要配置 plugins)

build: { vendor: ['~/plugins/axios.js'] }
Copy after login

这样在打包的时候,就会把 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
Copy after login

Nuxt.js 内置引用了 vuex 模块,不需要额外安装

上面的代码中,我在 actions 中写了一个 loadAboutMeInfo() 方法,用来请求 /api/about 接口

然后在 about.vue 页面中调用

// about.vue  
Copy after login

成果演示:

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

JS使用createElement()动态添加HTML

vue-infinite-loading做出无限加载效果

The above is the detailed content of Vue+Nuxt.js makes server-side rendering. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn