从0到1构建vueSSR项目之路由的构建


Posted in Javascript onMarch 07, 2019

vue开发依赖的相关配置

Vue SSR 指南

今天先做客户端方面的配置,明天再做服务端的部分。

那么马上开始吧~

修改部分代码

脚手架生成的代码肯定是不适合我们所用的 所以要修改一部分代码

//App.vue
<template>
  <div id="app">
    <router-view></router-view>
  </div>
</template>

<script>
export default {
  name: 'app'
}
</script>

<style>
  html,body,#app,#app>*{
    width: 100%;
    height: 100%;
  }
  body{
    font-family: 'Avenir', Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-align: center;
    color: #2c3e50;
    font-size: 16px;
    margin: 0;
    overflow-x: hidden;
  }

  img{
    width: 200px;
  }
</style>

修改main.js

为什么要这么做?为什么要避免状态单例

main.js 是我们应用程序的「通用 entry」。

在纯客户端应用程序中,我们将在此文件中创建根 Vue 实例,并直接挂载到 DOM。

但是,对于服务器端渲染(SSR),责任转移到纯客户端 entry 文件。

main.js 简单地使用 export 导出一个 createApp 函数:

import Vue from 'vue';
Vue.config.productionTip = false;
import App from './App.vue';
//router store 实例
//这么做是避免状态单例
export function createApp() {

  const app = new Vue({
    //挂载router,store
    render: h => h(App)
  })
  //暴露app实例
  return { app };
}

添加Vue.config.js配置

webpack的入口文件有两个,一个是客户端使用,一个是服务端使用。

为何这么做?

今天只做客户端部分。

src/vue.config.js
  module.exports = {
    css: {
      extract: false//关闭提取css,不关闭 node渲染会报错
    },
    configureWebpack: () => ({
      entry: './src/entry/client'
    })
  }

根目录创建 entry 文件夹,以及webpack入口代码

mdkir entry
  cd entry
  创建 入口文件
    client.js 作为客户端入口文件。
    server,js 作为服务端端入口文件。 //先创建不做任何配置
  entry/client.js

    import { createApp } from '../main.js';

    const { app } = createApp();

    app.$mount('#app');

路由和代码分割

官方说明的已经很清楚了,我就不做过多介绍了,下面直接展示代码

添加新路由,这里将存放pages的相关路由

src/pages/router/index.js

/**
 *
 * @method componentPath 路由模块入口
 * @param {string} name 要引入的文件地址
 * @return {Object}
 */
function componentPath (name = 'home'){
  return {
    component:() => import(`../${name}/index.vue`)
  }
}

export default [
  {
    path: '/home',
    ...componentPath(),
    children: [
      {
        path: "vue",
        name: "vue",
        ...componentPath('home/vue')
      },
      {
        path: "vuex",
        name: "vuex",
        ...componentPath('home/vuex')
      },
      {
        path: "vueCli3",
        name: "vueCli3",
        ...componentPath('home/vueCli3')
      },
      {
        path: "vueSSR",
        name: "vueSSR",
        ...componentPath('home/vueSSR')
      }
    ]

  }
]

src/router.config.js作为路由的总配置 易于管理

//路由总配置
  import Vue from 'vue';
  import VueRouter from 'vue-router';

  Vue.use(VueRouter);
  //为什么采用这种做法。
  //如果以后有了别的大模块可以单独开个文件夹与pages平级
  //再这里导入即可。这样易于管理

  // pages
  import pages from './pages/router';

  export function createRouter() {
    return new VueRouter({
      mode: 'history',
      routes: [
        {
          path: "*",
          redirect: '/home/vue'
        },
        ...pages
      ]
    })
  }

更新main.js

import Vue from 'vue';
Vue.config.productionTip = false;
import App from './App.vue';
+ import { createRouter } from './router.config.js'
//router store 实例
//这么做是避免状态单例
export function createApp() {
+  const router = createRouter()
  const app = new Vue({
+    router,
    render: h => h(App)
  })
  //暴露app,router实例
  return { app, router };
}

更新 client.js

由于使用的路由懒加载,所以必须要等路由提前解析完异步组件,才能正确地调用组件中可能存在的路由钩子。

// client.js
import { createApp } from '../main.js';

const { app, router } = createApp();

router.onReady( () => {
  app.$mount('#app');
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS中操作JSON总结
Dec 06 Javascript
js调用浏览器打印模块实现点击按钮触发自定义函数
Mar 21 Javascript
js操作输入框提示信息且响应鼠标事件
Mar 25 Javascript
TypeScript具有的几个不同特质
Apr 07 Javascript
Javascript中typeof 用法小结
May 12 Javascript
JavaScript中的prototype原型学习指南
May 09 Javascript
Angular2-primeNG文件上传模块FileUpload使用详解
Jan 14 Javascript
Node.js中你不可不精的Stream(流)
Jun 08 Javascript
2019 年编写现代 JavaScript 代码的5个小技巧(小结)
Jan 15 Javascript
基于Vue插入视频的2种方法小结
Apr 02 Javascript
JS中FileReader类实现文件上传及时预览功能
Mar 27 Javascript
解决Echarts2竖直datazoom滑动后显示数据不全的问题
Jul 20 Javascript
bootstrap-table实现表头固定以及列固定的方法示例
Mar 07 #Javascript
js如何获取图片url的Blob值并预览示例代码
Mar 07 #Javascript
mpvue全局引入sass文件的方法步骤
Mar 06 #Javascript
angular6根据environments配置文件更改开发所需要的环境的方法
Mar 06 #Javascript
vue项目前端埋点的实现
Mar 06 #Javascript
vue2.0结合Element-ui实战案例
Mar 06 #Javascript
JS使用JSON.parse(),JSON.stringify()实现对对象的深拷贝功能分析
Mar 06 #Javascript
You might like
php 生成文字png图片的代码
2011/04/17 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
jQuery 开发者应该注意的9个错误
2012/05/03 Javascript
javascript为按钮注册回车事件(设置默认按钮)的方法
2015/05/09 Javascript
分享经典的JavaScript开发技巧
2015/11/21 Javascript
Javascript技术栈中的四种依赖注入详解
2016/02/23 Javascript
静态页面html中跳转传值的JS处理技巧
2016/06/22 Javascript
js只执行1次的函数示例
2016/07/20 Javascript
浅谈JavaScript作用域和闭包
2017/09/18 Javascript
vue地区选择组件教程详解
2018/05/04 Javascript
vue watch普通监听和深度监听实例详解(数组和对象)
2018/08/16 Javascript
深入理解NodeJS 多进程和集群
2018/10/17 NodeJs
react+redux仿微信聊天界面
2019/06/21 Javascript
如何修改Vue打包后文件的接口地址配置的方法
2020/04/22 Javascript
JavaScript内置对象之Array的使用小结
2020/05/12 Javascript
微信小程序实现导航栏和内容上下联动功能代码
2020/06/29 Javascript
Python3实现从文件中读取指定行的方法
2015/05/22 Python
python处理Excel xlrd的简单使用
2017/09/12 Python
python dataframe常见操作方法:实现取行、列、切片、统计特征值
2018/06/09 Python
python字符串和常用数据结构知识总结
2019/05/21 Python
Django框架会话技术实例分析【Cookie与Session】
2019/05/24 Python
python常用库之NumPy和sklearn入门
2019/07/11 Python
python实现sm2和sm4国密(国家商用密码)算法的示例
2020/09/26 Python
python语言time库和datetime库基本使用详解
2020/12/25 Python
英国顶级珠宝品牌之家:John Greed
2018/06/09 全球购物
WINDOWS域的具体实现方式是什么
2014/02/20 面试题
自动化职业生涯规划书范文
2014/01/03 职场文书
护理专业自荐信范文
2014/02/26 职场文书
团队精神口号
2014/06/06 职场文书
物业公司的岗位任命书
2014/06/06 职场文书
党员个人对照检查材料思想汇报
2014/09/16 职场文书
2015年保洁员工作总结
2015/05/04 职场文书
贴吧吧主申请感言
2015/08/03 职场文书
Python利用Turtle绘制哆啦A梦和小猪佩奇
2022/04/04 Python
根德5570型九灯四波段立体声收音机是电子管收音机的楷模 ? 再论5570
2022/04/05 无线电
pd.DataFrame中的几种索引变换的实现
2022/06/16 Python