Home Web Front-end JS Tutorial Detailed explanation of Vue's server-side rendering based on Nuxt.js

Detailed explanation of Vue's server-side rendering based on Nuxt.js

May 26, 2018 pm 03:02 PM
javascript based on

Directly use Vue to build a front-end single-page application. The page source code only has a few simple lines of HTML, which is not conducive to the SEO of the website. At this time, server-side rendering is required. This article mainly introduces the detailed explanation of Vue based on Nuxt.js Implementing server-side rendering (SSR) has certain reference value. Interested friends can refer to

Directly use Vue to build a front-end single-page application. The page source code only has a few simple lines of HTML. This does not It is not conducive to the SEO of the website, so server-side rendering is required at this time.

On October 25, 2016, the team behind zeit.co released a React server-side rendering application framework Next.js

A few hours later, a server-side rendering application framework based on Vue.js came into being, which is similar to Next.js. This is Nuxt.js

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

MyProject Is the name of the project folder, which can be customized

Through npm install (it seems to be smoother with yarn install) After installing the dependencies, you can directly npm run dev in the development environment Start the project

The default startup address is http://localhost:3000/, you can add the following configuration in package.json to 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

The generated project directory is as follows

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

Among them, there are three directories that are critical for price comparison:

1. components component directory

is generally used to store non-pages Components at level , 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 the default.vue in this directory to modify the default layout

<template>
 <p>
  <my-header></my-header>
  <nuxt/>
  <my-footer></my-footer>
 </p>
</template>
Copy after login

Among them is required, the main content of the page 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

Used to store page-level components, nuxt will generate routes based on the page structure in this directory

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

router: {
 routes: [
  {
   name: &#39;index&#39;,
   path: &#39;/&#39;,
   component: &#39;pages/index.vue&#39;
  },
  {
   name: &#39;about&#39;,
   path: &#39;/about&#39;,
   component: &#39;pages/about.vue&#39;
  },
  {
   name: &#39;classroom&#39;,
   path: &#39;/classroom&#39;,
   component: &#39;pages/classroom.vue&#39;,
   children: [
    {
     path: &#39;student&#39;,
     component: &#39;pages/classroom/student.vue&#39;,
     name: &#39;student&#39;
    },
    { //定义带参数的动态路由,需要创建对应的以下划线作为前缀的 Vue 文件或目录
     path: &#39;:id&#39;,
     component: &#39;pages/classroom/_id.vue&#39;,
     name: &#39;classroom-id&#39;
    }
   ]
  }
 ]
}
Copy after login

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

Among them, the

asyncData method is more commonly used and supports asynchronous data processing.

This method will be called before each load of the

page component, then obtains the data and returns it to 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: &#39;not found&#39; })
  })
 }
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, there is no way to reference the component through this within the method. Instance object

3. Using plug-ins

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

But if other pages also introduce the same plug-in, 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: [&#39;~/plugins/elementUI.js&#39;]
 },
 plugins: [
  {src: &#39;~/plugins/elementUI.js&#39;},
 ]
Copy after login

The plugins attribute here is used To configure the vue.js plug-in, that is,

You can use the Vue.user() method of the plug-in

By default, only the src attribute is required. In addition, you can also configure ssr: false to make the file only available in The client is packaged and introduced

If it is a third-party (cannot be used) plug-in like axios, you only need to create axios.js in the plugins directory

// axios.js

import Vue from &#39;vue&#39;
import axios from &#39;axios&#39;

const service = axios.create({
 baseURL: &#39;/api&#39;
})

Vue.prototype.$ajax = axios
export default service
Copy after login

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

build: {
 vendor: [&#39;~/plugins/axios.js&#39;]
}
Copy after login

这样在打包的时候,就会把 axios 打包到 vendor.js 中

四、Vuex 状态树

如果在 store 目录下创建了 index.js,nuxt.js 会根据该目录下的文件创建 Vuex 状态树

// store/index.js

import Vue from &#39;vue&#39;
import Vuex from &#39;vuex&#39;
import Axios from &#39;~/plugins/axios.js&#39;;

Vue.use(Vuex)

const store = () => new Vuex.Store({
 state: {
  author: &#39;WiseWrong&#39;,
  info: &#39;&#39;
 },
 mutations: {
  setInfo (state, val) {
   state.info = val
  }
 },
 actions: {
  loadAboutMeInfo ({commit, state}) {
   return Axios.get(`/about`)
    .then(res => {
     console.log(&#39;ajax is success&#39;)
     console.log(res.data.info)
     commit(&#39;setInfo&#39;, res.data.info)
    })
    .catch(err => {
     console.log(&#39;error&#39;)
    })
  }
 }
})

export default store
Copy after login

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

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

然后在 about.vue 页面中调用

// about.vue 

<template>
 <section class="container">
  <p>
   <img src="~/assets/about.png" alt="">
  </p>
  <h1>{{$store.state.info}}</h1>
 </section>
</template>

<script>
export default {
 fetch({ store }) {
  return store.dispatch(&#39;loadAboutMeInfo&#39;)
 },
 name: &#39;about&#39;,
 data () {
  return {}
 }
}
</script>
Copy after login

成果演示:

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

ajax请求之返回数据的顺序问题分析

Ajax异步提交数据返回值的换行问题实例分析

防止重复发送Ajax请求的解决方案


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

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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to implement an online speech recognition system using WebSocket and JavaScript How to implement an online speech recognition system using WebSocket and JavaScript Dec 17, 2023 pm 02:54 PM

How to use WebSocket and JavaScript to implement an online speech recognition system Introduction: With the continuous development of technology, speech recognition technology has become an important part of the field of artificial intelligence. The online speech recognition system based on WebSocket and JavaScript has the characteristics of low latency, real-time and cross-platform, and has become a widely used solution. This article will introduce how to use WebSocket and JavaScript to implement an online speech recognition system.

WebSocket and JavaScript: key technologies for implementing real-time monitoring systems WebSocket and JavaScript: key technologies for implementing real-time monitoring systems Dec 17, 2023 pm 05:30 PM

WebSocket and JavaScript: Key technologies for realizing real-time monitoring systems Introduction: With the rapid development of Internet technology, real-time monitoring systems have been widely used in various fields. One of the key technologies to achieve real-time monitoring is the combination of WebSocket and JavaScript. This article will introduce the application of WebSocket and JavaScript in real-time monitoring systems, give code examples, and explain their implementation principles in detail. 1. WebSocket technology

How to implement an online reservation system using WebSocket and JavaScript How to implement an online reservation system using WebSocket and JavaScript Dec 17, 2023 am 09:39 AM

How to use WebSocket and JavaScript to implement an online reservation system. In today's digital era, more and more businesses and services need to provide online reservation functions. It is crucial to implement an efficient and real-time online reservation system. This article will introduce how to use WebSocket and JavaScript to implement an online reservation system, and provide specific code examples. 1. What is WebSocket? WebSocket is a full-duplex method on a single TCP connection.

How to use JavaScript and WebSocket to implement a real-time online ordering system How to use JavaScript and WebSocket to implement a real-time online ordering system Dec 17, 2023 pm 12:09 PM

Introduction to how to use JavaScript and WebSocket to implement a real-time online ordering system: With the popularity of the Internet and the advancement of technology, more and more restaurants have begun to provide online ordering services. In order to implement a real-time online ordering system, we can use JavaScript and WebSocket technology. WebSocket is a full-duplex communication protocol based on the TCP protocol, which can realize real-time two-way communication between the client and the server. In the real-time online ordering system, when the user selects dishes and places an order

JavaScript and WebSocket: Building an efficient real-time weather forecasting system JavaScript and WebSocket: Building an efficient real-time weather forecasting system Dec 17, 2023 pm 05:13 PM

JavaScript and WebSocket: Building an efficient real-time weather forecast system Introduction: Today, the accuracy of weather forecasts is of great significance to daily life and decision-making. As technology develops, we can provide more accurate and reliable weather forecasts by obtaining weather data in real time. In this article, we will learn how to use JavaScript and WebSocket technology to build an efficient real-time weather forecast system. This article will demonstrate the implementation process through specific code examples. We

Simple JavaScript Tutorial: How to Get HTTP Status Code Simple JavaScript Tutorial: How to Get HTTP Status Code Jan 05, 2024 pm 06:08 PM

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

How to use insertBefore in javascript How to use insertBefore in javascript Nov 24, 2023 am 11:56 AM

Usage: In JavaScript, the insertBefore() method is used to insert a new node in the DOM tree. This method requires two parameters: the new node to be inserted and the reference node (that is, the node where the new node will be inserted).

How to get HTTP status code in JavaScript the easy way How to get HTTP status code in JavaScript the easy way Jan 05, 2024 pm 01:37 PM

Introduction to the method of obtaining HTTP status code in JavaScript: In front-end development, we often need to deal with the interaction with the back-end interface, and HTTP status code is a very important part of it. Understanding and obtaining HTTP status codes helps us better handle the data returned by the interface. This article will introduce how to use JavaScript to obtain HTTP status codes and provide specific code examples. 1. What is HTTP status code? HTTP status code means that when the browser initiates a request to the server, the service

See all articles