欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue开发实践指南之应用入口

程序员文章站 2022-03-02 08:56:41
目录前言创建应用添加 loading 效果开始创建应用多页面改造总结前言vue 开发实践为本人的最佳实践,非业内最佳,仅用于提供给各位做参考,这是系列文,但发布时间和内容不固定。通常情况下一个 前端工...

前言

vue 开发实践为本人的最佳实践,非业内最佳,仅用于提供给各位做参考,这是系列文,但发布时间和内容不固定。

通常情况下一个 前端工程 只会导出 一个 前端单页应用,而 main.js 就是这个应用的入口文件。

创建应用

默认情况下 src/main.js 是直接初始化一个 vue 应用

import vue from 'vue'

import app from './app.vue'
import router from './router'
import store from './store'

new vue({
  store,
  router,
  render: h => h(app)
}).$mount('#app')

但在后台类项目中,应用在被用户可操作前,一定是需要登录的,这就导致很多时候,我们会套一个函数。

import vue from 'vue'

import app from './app.vue'
import router from './router'
import store from './store'

function render() {
  new vue({
    store,
    router,
    render: h => h(app)
  }).$mount('#app')
}

这样只要不调用 render 函数,那么应用就不会被创建,用户也就无法操作。

添加 loading 效果

但这样会导致页面处于空白状态,为了友好,可以加一些加载动画效果.

打开 public/index.html 文件,将你的 loading 效果放在 div#app 中。

<body>
  <div id="app">
    <!-- 这里写你的 loading 动画 -->
  </div>
</body>

当我们创建应用,vue 会自动清空 div#app 里面的内容,所以不需要关系初始化后的清理工作。

开始创建应用

当有了 loading 动画之后,我们就可以去获取,如 授权认证 和 菜单获取 等操作。

import vue from 'vue'

import app from './app.vue'
import router from './router'
import store from './store'

function render() {
  new vue({
    store,
    router,
    render: h => h(app)
  }).$mount('#app')
}

async function main() {
  // 获取用户信息,没有就跳转到登录页
  // 获取菜单数据
}

main().then(render)

一旦数据准备完毕,应用就显示了,就不会出现应用一闪而过的问题了。

多页面改造

正常而言,一个 前端工程 只会存在一个 前端应用,也就是比较熟悉的 spa 模式,但有时候也需要导出多个 html 文件,每一个 html 文件都对应一个 vue 实例,这种开发模式也被称为 mpa 模式。

但不管是 spa 还是 mpa,对于工程而言,源码都是放在一起的,所以配置都是一样的。

vue cli 默认的应用类型是 spa 单页应用,但在提供了 pages 字段。

// vue.config.js

module.exports = {
  // 详见 https://cli.vuejs.org/zh/config/#pages
  pages: {
    index: {
      title: '首页',
      entry: 'src/main.js',
    },
    login: {
      title: '登录页',
      entry: 'src/login.js',
    },
  }
}

添加 登录页 的 应用入口 和 应用视图 文件

 ├── src/
 │ ├── views/
+│ │   └── login/
+│ │       └── login.vue  # 应用视图
+│ ├── login.js           # 应用入口  
 │ └── main.js
 ├── vue.config.js 
 └── package.json

创建视图文件

<template>
  <!-- src/login/login.vue -->
  <div> this is login page</div>
</template>

创建应用入口

// /src/login.js

import vue from 'vue'

import login from './views/login/login.vue'


new vue({
  render: h => h(login)
}).$mount('#app')

重启你的应用

# 启动之后,在当前项目项目地址后面加上 login.html 就可以看到新增的页面了
$ open http://localhost:8080/login.html

总结

到此这篇关于vue开发实践指南之应用入口的文章就介绍到这了,更多相关vue应用入口内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关标签: vue 应用 入口