2020-05-22 17:51:02 +08:00
2020-05-22 17:51:02 +08:00
2020-05-22 17:51:02 +08:00
2020-05-22 15:22:32 +08:00
2020-05-22 15:26:29 +08:00
2020-05-22 15:38:04 +08:00
2020-05-22 16:39:43 +08:00
2020-05-22 16:39:43 +08:00
2020-05-22 16:39:43 +08:00
2020-05-22 16:39:43 +08:00

Vue2-SPA

可能是全网最干净的 vue 仓库 A Vue.js project with axios/vue-router/webpack

Live Demo

The live demo can be found in https://allan2coder.github.io/VUE2-SPA-Tutorial/ (移动端打开浏览器开发者工具并调到手机窗口浏览。注该项目同时适合PC端)

How to use

You should clone the repo and install the dependencies, and then npm start.That is all.

$ git clone https://github.com/allan2coder/VUE2-SPA-Tutorial.git
$ cd VUE2-SPA-Tutorial
$ npm install

Then launch the project app.

$ npm start

You should see a new browser tap opening and a page of 'index.html' in http://localhost:8080.

How to build the static files

npm run build

Lifecycle

image

Router

HTML


import Vue from 'vue'
import VueRouter from 'vue-router'

<template>
    <!-- 使用 router-link 组件来导航. -->
    <!-- 通过传入 `to` 属性指定链接. -->
    <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
    <p>
      <router-link to="/foo">Go to Foo</router-link>
      <router-link to="/bar">Go to Bar</router-link>
    </p>
    <!-- 路由出口 -->
    <!-- 路由匹配到的组件将渲染在这里 -->
    <router-view></router-view>
  </div>
</template>

or

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router"></script>

<div id="app">
  <p>
    <router-link to="/foo">Go to Foo</router-link>
    <router-link to="/bar">Go to Bar</router-link>
  </p>
  <router-view></router-view>
</div>

JavaScript


// 0. 如果使用模块化机制编程導入Vue和VueRouter要调用 vue.use(vuerouter)

// 1. 定义(路由)组件。
// 可以从其他文件 import 进来
const Foo = { template: '<div>foo</div>' }
const Bar = { template: '<div>bar</div>' }

// 2. 定义路由
// 每个路由应该映射一个组件。 其中"component" 可以是
// 通过 Vue.extend() 创建的组件构造器,
// 或者,只是一个组件配置对象。
const routes = [
  { path: '/foo', component: Foo },
  { path: '/bar', component: Bar }
]

// 3. 创建 router 实例,然后传 `routes` 配置
// 你还可以传别的配置参数, 不过先这么简单着吧。
const router = new VueRouter({
  routes // (缩写)相当于 routes: routes
})

// 4. 创建和挂载根实例。
// 记得要通过 router 配置参数注入路由,
// 从而让整个应用都有路由功能
const app = new Vue({
  router
}).$mount('#app')

// 现在,应用已经启动了!

有关打包优化

第三方库单独打包

npm i autodll-webpack-plugin -D

webpack 配置:

new AutoDllPlugin({
  inject: true, // will inject the DLL bundle to index.html
  debug: true,
  filename: '[name]_[hash].js',
  path: './dll',
  entry: {
    vendor: ['vue', 'vue-router'] // webpack 会去 `node_modules` 去找
  }
})

每次打包,这个插件都会检查注册在 entry 中的第三方库。如果没有变化,插件就会使用缓存中的打包文件,减少了打包的时间,这时 Hash 也不会变化。

Other SPA(其他单页)

Reference Articles

Description
vue3 + vite + nut ui + sass + viewport 适配方案 +axios 封装
Readme 11 MiB
Languages
TypeScript 43.1%
CSS 23.2%
Vue 22.1%
JavaScript 8.6%
HTML 2.6%
Other 0.4%