最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Nuxt.js(Vue SSR)项目配置以及开发细节

    正文概述 掘金(卡尔特斯)   2021-02-02   597

    一、项目中不要使用 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,加上下面配置:

    Nuxt.js(Vue SSR)项目配置以及开发细节

    css: [
      'ant-design-vue/dist/antd.css',
      '~/assets/css/reset.css',
      '~/assets/iconfont/iconfont.css'
    ],
    

    附带一下 iconfontplugins 配置,如果需要重写路由拦截也可以添加到这里面

    plugins: [
      '@/plugins/antd-ui',
      // '@/plugins/router', // 路由守卫
      { src: '@/assets/iconfont/iconfont.js', ssr: false } // iconfont
    ],
    

    九、项目中 加载更多功能,目前好像没有办法能做到,至少系统是不提供的,asyncData() 方法不支持重复调用的,所以暂时是没找到方式做这个功能的,只能每次通过 a 标签重新加载页面。


    起源地下载网 » Nuxt.js(Vue SSR)项目配置以及开发细节

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元