SSR(服务端与客户端渲染)、NUXT.js(介绍安装、配置、路由、视图、异步数据与反向代理解决跨域、vuex状态树)(九)

nuxt

一. SSR

什么是服务端渲染? 核心在于方便seo优化

后端先调用数据库,获得数据之后,将数据和页面元素进行拼装,组合成完整的html页面,再直接返回给浏览器,以便用户浏览。 例如:http://www.cnblogs.com/cate/design

什么是客户端渲染? 分担到客户端

数据由浏览器通过ajax动态获得,再通过js将数据填充到dom元素上最终展示到网页中,这样的过程就叫做客户端渲染。 例如:https://m.maizuo.com/v5/#/films/nowPlaying

服务端渲染与客户端渲染区别?

客户端渲染不利于SEO搜索引擎优化
服务端渲染是可以被爬虫抓取到的,客户端异步渲染是很难被爬虫抓取到的
服务端渲染对SEO友好,经过服务端渲染的页面,在网络传输的时候,传输的是一个真实的页面,所以爬虫就会对这个页面中的关键数据进行分析、收录。
服务端渲染缺点就是 对服务器压力比较大
客户端渲染减轻了服务器端的渲染压力,能够实现前后端分离开发
客户端渲染缺点就是 对SEO相当的不友好

二. Nuxt.js

1. Nuxt.js介绍与安装(一个基于 Vue.js 的服务端渲染应用框架 )

https://zh.nuxtjs.org/guide

npx create-nuxt-app <项目名>

服务端渲染,解决首屏加载速度,和 seo问题

2. Nuxt.js的配置

https://zh.nuxtjs.org/guide/configuration

3. 路由

Nuxt.js 依据 pages 目录结构自动生成 vue-router 模块的路由配置。

(1)要在页面之间使用路由,使用 支持activeClass、tag
(2)嵌套路由

创建内嵌子路由,你需要添加一个 Vue 文件,同时添加一个与该文件同名的目录用来存放子视图组件。
路径如下:

1 pages/
2 ‐‐| film/
3 ‐‐‐‐‐| nowplaying.vue
4 ‐‐‐‐‐| comingsoon.vue
5 --| film.vue

(3)动态路由

必须加下划线 (文件夹也可以加下划线(多级嵌套), 文件也可以加下划线)

1 pages/
2 ‐‐| detail/
3 ‐‐‐‐‐| _id.vue

(4)获取动态路由参数

1 asyncData({params}){
2 console.log(params.id);
3 }

(5)路由的重定向 (nuxt.config.js)

router: {
	extendRoutes(routes, resolve) {
		routes.push({
			path: "/",
			redirect: "/film"
		})
	
 	  varindex = routes.findIndex(item=>item.path === "/film")
      routes[index].children.push({
	      path:"/film",
	      redirect:"/film/nowplaying"
      })
	}
}

还可以通过中间件的方式进行配置(middleware/redirect.js)

export default function ({ route,redirect}){
	if(route.fullPath === "/film"){
		return redirect("/film/nowplaying")
	}
}
router: {
	extendRoutes(routes, resolve) {
		routes.push({
			path: "/",
			redirect: "/film"
		})
	},
	middleware:["redirect"]
}
4.视图

在layout 里面写好default.vue 可以认为这是根组件的模板了,
所有的组件都加在里面,但是有些页面可能不一样,就可以使用个性化定制页面。

export default {
	layout:"detailTpl"
}
5. 异步数据与反向代理解决跨域

(1) 如果组件的数据不需要异步获取或处理,可以直接返回指定的字面对象作为组件的数据。
(2) 通过asyncData来异步请求数据

因为在created里面实现异步的话,对于搜索引擎来说是不知道的。

第一次刷新的时候是后端自己触发asyncData,异步获取到数据,然后进行组装,组装完毕后再将数据回传给前端进行显示,有利于seo搜索引擎优化。
后续的都是前端去调用asyncData这个方法,属于单页应用了,有利于用户体验

asyncData(){
	return axios({
		url:"https://m.maizuo.com/gateway?cityId=440100&pageNum=1&pageSize=10&type=1&k=3273067",
		headers:{
			"X-Host": "mall.film-ticket.film.list"
		}
	}).then(res=>({
		datalist:res.data.data.films
	}))
}

跨域的解决方案: cnpm i @nuxtjs/proxy

modules: [
	'@nuxtjs/axios',
	'@nuxtjs/proxy',
],
axios: {
	proxy:true
},
proxy:{
	"/ajax":{
		target:"http://m.maoyan.com",
		changeOrigin:true
	}
}
asyncData ({ params }) {
	const url = process.server?"http://m.maoyan.com":""
	return axios({
		method:"get",
		url:url+"/ajax/mostExpected?ci=60&limit=10&offset=0&token=&optimus_uuid=A3531DF0B63711E8940A97B13D035BD69C7A62A9A316420284E6E4A55D748820&optimus_risk_level=71&optimus_code=10",
	}).then((res) => {
		return { datalist: res.data.coming }
	})
},
6. vuex状态树
export const state = () => ({
	counter: 0
})
export const mutations = {
	increment(state) {
	state.counter++
},
changeCounter(state, count) {
	state.counter = count
}
...mapState('todo',['counter'])
...mapMutations('todo',['increment'])

(2)fetch 方法用于在渲染页面前填充应用的状态树(store)数据,与 asyncData 方法类似,不同的是它不会设置组件的数据。

如果页面组件设置了 fetch 方法,它会在组件每次加载前被调用(在服务端或切换至目标路由之前)。

async fetch({store}){
	let { data } = await axios.get(process.server?"http://m.maoyan.com/ajax/movieOnInfoList?token=":'/ajax/movieOnInfoList?token=')
	store.commit('todo/changeCounter', data.movieList[0].showst)
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue SSR(Server Side Rendering)服务渲染是一种在服务将Vue组件渲染成HTML字符串的技术。Vue SSR可以提高应用程序的性能和搜索引擎优化。在此基础上,Nuxt.js是一个基于Vue.js的通用应用框架,它通过一个命令行工具来创建和管理Vue SSR应用程序。Nuxt.js提供了一些默认的配置,使得创建Vue SSR应用程序变得非常简单。 CNode社区是一个专门讨论Node.js技术的社区,许多Node.js开发者都会在这里交流。在本文中,我们将使用Nuxt.js来创建一个CNode社区的SSR应用程序。我们将使用CNode社区提供的API来获取帖子列表,然后使用Nuxt.js来将其渲染成HTML字符串,最后将其呈现给用户。 首先,我们需要安装Nuxt.js和一些必要的依赖项。可以使用以下命令来安装: ``` npm install --save nuxt axios ``` 接下来,我们需要配置Nuxt.js。我们可以在项目的根目录中创建一个`nuxt.config.js`文件来配置Nuxt.js。我们需要配置Nuxt.js的一些选项,例如页面路由、构建选项、插件等等。以下是一个简单的配置示例: ```javascript module.exports = { head: { title: 'CNode社区', meta: [ { charset: 'utf-8' }, { name: 'viewport', content: 'width=device-width, initial-scale=1' }, ], }, modules: ['@nuxtjs/axios'], axios: { baseURL: 'https://cnodejs.org/api/v1', }, plugins: ['~/plugins/vue-markdown.js'], }; ``` 在上面的配置中,我们设置了页面标题,设置了meta标签,使用了`@nuxtjs/axios`模块来发送HTTP请求,设置了API的基本URL,以及添加了一个Vue插件来渲染Markdown。 接下来,我们需要创建页面。在Nuxt.js中,每个`.vue`文件都可以作为一个页面,它们位于`pages`目录中。我们可以创建一个名为`index.vue`的文件来显示CNode社区的帖子列表。以下是`index.vue`的示例代码: ```html <template> <div> <h1>CNode社区</h1> <ul> <li v-for="post in posts" :key="post.id"> <router-link :to="'/post/' + post.id">{{ post.title }}</router-link> </li> </ul> </div> </template> <script> export default { asyncData({ $axios }) { return $axios.get('/topics').then((res) => { return { posts: res.data.data }; }); }, }; </script> ``` 在上面的代码中,我们使用了Vue.js的`v-for`指令来遍历每个帖子,并使用Vue.js的`router-link`组件来呈现帖子标题和链接。我们还使用了Nuxt.js提供的`asyncData`方法来在服务获取帖子列表。在这个方法中,我们使用了`$axios`模块来发送HTTP请求,获取帖子列表数据,并将其存储在`posts`变量中。 最后,我们需要启动应用程序。可以使用以下命令来启动: ``` npm run dev ``` 这将启动一个本地服务器,可以在浏览器中访问`http://localhost:3000`来查看我们的应用程序。 总结一下,通过Nuxt.js和Vue SSR技术,我们可以快速创建一个CNode社区帖子列表的SSR应用程序。我们只需要简单地配置Nuxt.js,然后创建一个`.vue`文件作为页面,并使用`asyncData`方法来获取数据渲染页面。 ### 回答2: Vue SSR服务渲染是指在服务将Vue组件渲染为HTML,然后将其发送给浏览器进行展示。这种技术的好处是可以提高页面的渲染速度和SEO友好性。 Nuxt.js是一个基于Vue.js服务渲染应用框架,它提供了很多方便的特性和工具,可以帮助我们快速开发和部署Vue SSR应用。 CNode社区是一个以Node.js为后,Vue.js为前的技术社区。我们可以使用Nuxt.js来打造CNode社区的SSR应用,从而提升用户体验和搜索引擎的收录。 首先,我们可以使用Nuxt.js的CLI工具来初始化一个新的项目,选择SSR模式。然后,我们可以根据CNode社区的需求,创建相应的页面组件,如首页、帖子详情页、用户个人中心等。 在创建这些页面组件的过程中,我们可以使用Nuxt.js提供的一些特性,如动态路由、全局组件等,来简化开发和提升复用性。 在每个页面组件中,我们可以通过asyncData方法来获取数据,并将其作为组件的属性进行渲染。这样,我们就可以在服务获取数据渲染好HTML,然后将其发送到浏览器进行展示。 为了提高页面的加载速度,我们可以使用Nuxt.js的代码拆分功能,将不同页面的代码拆分成多个小块,并按需加载。这样,用户只需要加载当前页面所需的代码,可以减少页面的加载时间。 最后,我们可以使用Nuxt.js的部署工具来快速部署CNode社区的SSR应用。Nuxt.js支持将应用打包成静态文件,并可以轻松地部署到各种服务器或服务商上。 总结来说,通过深入学习Vue SSR服务渲染,借助Nuxt.js框架,我们可以有效地打造CNode社区的SSR应用,提升用户体验和搜索引擎的收录,从而更好地为用户提供技术交流和资源分享的平台。 ### 回答3: Vue SSR服务渲染)是一种将Vue应用程序在服务进行渲染的技术。通过使用服务渲染,可以将静态HTML页面返回给客户浏览器,从而提高首次加载速度和搜索引擎的抓取能力。而Nuxt.js是一个基于Vue SSR的框架,提供了一整套开箱即用的功能以快速构建Vue SSR应用程序。 在使用Nuxt.js构建CNode社区时,我们可以深入学习Vue SSR服务渲染的原理和技巧。首先,我们需要了解Nuxt.js提供的目录结构和配置文件,这些会帮助我们更好地组织和管理前开发流程。接下来,我们需要学习如何使用Nuxt.js路由系统和异步数据获取功能,这些能帮助我们实现动态的页面渲染数据预取。 在深入学习Vue SSR服务渲染时,我们还需要了解服务渲染的优势和限制。通过SSR,我们可以提供更好的搜索引擎优化和用户体验,但也需要注意应用程序中可能出现的问题,比如对于某些浏览器不支持的特性、第三方库的兼容性和性能方面的考虑等。 除此之外,为了更好地打造CNode社区,我们还需要学习如何使用Nuxt.js的插件系统和组件库,以及如何与后API进行交互和数据处理。通过深入学习Vue SSR服务渲染和使用Nuxt.js打造CNode社区,我们可以提升自己的前开发技能,并且能够快速构建出高效、可扩展的Vue SSR应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值