一、项目中不要使用 v-if
- 使用
v-if
会在查看源码的时候无法显示标签,需要换成v-show
二、项目中跳转页面尽量使用 a
标签
- 无论使用
vue router
还是使用nuxt-link
都不如使用a
标签,而且前两者在服务器渲染中有时候还会有别的问题发生,所以可以直接使用a
标签省事,避免了坑。
三、项目中更换 favicon.ico
不生效,可以编译一下,启动正式环境,就生效了。
四、项目中 请求接口数据,并服务器渲染
,asyncData()
多接口请求的使用:
// asyncData 函数是 Nuxt.js 的生命周期函数,每个页面只能实现一次 // 多接口请求 async asyncData () { let [request1Data, request2Data, request3Data] = await Promise.all([ getCreator(), getIndustryList() axios.get('http://localhost:3000/api/api/h5/creator/2795') ]) return { creator: request1Data.data.data.channelCreator, videoList: request1Data.data.data.videoList, data2: request2Data.data data3: request3Data.data } } // 单个接口请求 asyncData () { return getCreator().then(res => { const { code, data } = res.data if (code === 0) { return { creator: data.channelCreator, videoList: data.videoList } } }) }
五、项目中 如何获取链接中带的参数,并使用:
// 这种方式获得的只能当前页面使用,但是无法参与服务器渲染使用,所以需要参与服务器渲染的还是得在 asyncData() 中获取 。 created () { // 初始化标签选中 this.industry = this.$route.params.tag || 0 // console.log(this.$route); } // asyncData() 函数里面会带回来一个上下文,这个对象里面有所有需要的对象集合 // https://www.nuxtjs.cn/api/context asyncData (context) { .... } // 获取链接中带的参数 async asyncData ({ query, params }) { .... }
六、项目中 自定义路由
,类似 Vue
一样,找到 nuxt.config.js
,加上下面配置:
// 自定义路由,以及页面参数 router: { extendRoutes(routes, resolve) { routes.push( { name: 'creator', path: '/creator/:id?/:tag?', component: resolve(__dirname, 'pages/creator-view.vue') }, { name: 'video', path: '/video/:id?', component: resolve(__dirname, 'pages/video-view.vue') } ) } },
七、项目中 添加代理
,类似 Vue
一样,找到 nuxt.config.js
,加上下面配置:
但是如果是 ssr
开发,就不存在跨域一说了,都是服务器直接组装好直接返回整个页面显示,因此也不需要配置。
axios: { proxy: true }, proxy: { '/api': { target: 'http://10.0.90.164:8081', changeOrigin: true, pathRewrite: { '^/api': '' } }, },
八、项目中添加 全局样式
、iconfont
等等,找到 nuxt.config.js
,加上下面配置:
- iconfont 使用配置
- 全局样式
css: [ 'ant-design-vue/dist/antd.css', '~/assets/css/reset.css', '~/assets/iconfont/iconfont.css' ],
- 如果需要重写路由拦截也可以添加到这里面
plugins: [ '@/plugins/antd-ui', // '@/plugins/router', // 路由守卫 ],
九、组件新建到自带的 components
文件夹中,可以直接使用,不需要在单个页面导入