一、安装node环境

这个之前做angular项目安装过,暂时先不整理,整理好vue相关知识再整理。

二、搭建vue项目环境

1、全局安装vue-cli

npm install --global vue-cli
不知道是不是网络问题,我使用上面命令安装失败,所以换成了下面命令,使用yarn安装
yarn global add vue-cli
npm install -g @vue/cli-init

yarn启动vue 服务 vue yarn build_yarn启动vue 服务

2、说明

vue --version:查看安装版本
Vue build:打包方式,回车即可
Install vue-router:是否安装vue-router,我们项目中需要用到,所以Y回车
后面的ESLint(语法检测),unit tests(单元测试),e2e...(端到端测试工具)暂时不需要,所以都是n回车

3、安装依赖

yarn install
安装成功后,项目文件夹会多出一个目录:node_modules

yarn启动vue 服务 vue yarn build_yarn启动vue 服务_02

4、启动项目

npm run dev

5、项目讲解

yarn启动vue 服务 vue yarn build_yarn启动vue 服务_03

(1)build:构建脚本目录
   1)build.js   ==>  生产环境构建脚本;
  2)check-versions.js   ==>  检查npm,node.js版本;
  3)utils.js   ==>  构建相关工具方法;
  4)vue-loader.conf.js   ==>  配置了css加载器以及编译css之后自动添加前缀;
  5)webpack.base.conf.js   ==>  webpack基本配置;
  6)webpack.dev.conf.js   ==>  webpack开发环境配置;
  7)webpack.prod.conf.js   ==>  webpack生产环境配置;
(2)config:项目配置
   1)dev.env.js   ==>  开发环境变量;
  2)index.js   ==>  项目配置文件;
  3)prod.env.js   ==>  生产环境变量;
(3)node_modules:npm 加载的项目依赖模块
(4)src:这里是我们要开发的目录,基本上要做的事情都在这个目录里。里面包含了几个目录及文件:
   1)assets:资源目录,放置一些图片或者公共js、公共css。这里的资源会被webpack构建;
  2)components:组件目录,我们写的组件就放在这个目录里面;
  3)router:前端路由,我们需要配置的路由路径写在index.js里面;
  4)App.vue:根组件;
  5)main.js:入口js文件;
(5)static:静态资源目录,如图片、字体等。不会被webpack构建
(6)index.html:首页入口文件,可以添加一些 meta 信息等
(7)package.json:npm包配置文件,定义了项目的npm脚本,依赖包等信息
(8)README.md:项目的说明文档,markdown 格式
(9).xxxx文件:这些是一些配置文件,包括语法配置,git配置等

三、开启vue项目代码之旅

1、在components目录下新建一个views目录,里面写我们的vue组件,创建第一个组件

(1)在views目录下新建first.vue

yarn启动vue 服务 vue yarn build_ios_04

(2)在router目录下的index.js里面配置路由路径

yarn启动vue 服务 vue yarn build_配置文件_05

(3)浏览器中输入ip地址:http://localhost:8080/#/first,页面如下

yarn启动vue 服务 vue yarn build_ios_06

(4)注意事项
a.一个组件下只能有一个并列的div
b.数据要写在 return 里面,而不是像文档那样子写

2、父子组件

(1)在components目录下新建sub文件夹,存放可复用的子组件,如新建confirm.vue

(2)在父组件first.vue中引用

yarn启动vue 服务 vue yarn build_配置文件_07


(3)父子组件互相通信

子组件:

yarn启动vue 服务 vue yarn build_yarn启动vue 服务_08


父组件:

yarn启动vue 服务 vue yarn build_ios_09

3、使用路由器官网地址:https://router.vuejs.org/zh-cn/

四、引用其他库

1、引用element组件库

官网地址:https://element.eleme.cn/#/zh-CN/component/installation
命令:npm i element-ui -S
引用:在main.js中进行配置
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);

2、引用less

安装less依赖包命令:
yarn add less@3.9.0 less-loader@5.0.0 --save

3、配置代理路径:config/index.js

参考:

4、使用地图

参考:https://elemefe.github.io/vue-amap/#/zh-cn/introduction/install

5、接口请求

(1)install axios
命令:npm install axios
(2)创建request.js
import axios from 'axios'
import { MessageBox, Message } from 'element-ui'
import store from '@/store'
const service = axios.create({
  baseURL: '', // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 1000000 // request timeout
})

// request interceptor
service.interceptors.request.use(
  config => {
    if (store.getters.token) {
      // let each request carry token
      // ['X-Token'] is a custom headers key
      // please modify it according to the actual situation
      // config.headers['X-Token'] = getToken()
    }
    return config
  },
  error => {
    // do something with request error
    console.log(error) // for debug
    return Promise.reject(error)
  }
)

// response interceptor
service.interceptors.response.use(
  /**
   * If you want to get http information such as headers or status
   * Please return  response => response
  */

  /**
   * Determine the request status by custom code
   * Here is just an example
   * You can also judge the status by HTTP Status Code
   */
  response => {
    // console.log(response)
    const res = response

    // if the custom code is not 1, it is judged as an error.
    if (res.status !== 200) {
      Message({
        message: res.message || 'Error',
        type: 'error',
        duration: 5 * 1000
      })

      // 50008: Illegal token; 50012: Other clients logged in; 50014: Token expired;
      if (res.status === 400 || res.status === 403) {
        // to re-login
        MessageBox.confirm('You have been logged out, you can cancel to stay on this page, or log in again', 'Confirm logout', {
          confirmButtonText: 'Re-Login',
          cancelButtonText: 'Cancel',
          type: 'warning'
        }).then(() => {
          store.dispatch('user/resetToken').then(() => {
            location.reload()
          })
        })
      }
      return Promise.reject(new Error(res.message || 'Error'))
    } else {
      return res.data
    }
  },
  error => {
    // TODO 有报错直接重新登陆吧
    console.log(error)
    if (error.response.request.responseURL.split('/api')[1] !== '/web/user/current') {
      Message({
        message: error.response.data.message,
        type: 'error',
        duration: 5 * 1000
      })
      if (error.message.indexOf('403') !== -1) {
        store.dispatch('user/resetToken').then(() => {
          location.reload()
        })
      }
    }
    return Promise.reject(error)
  }
)

export default service
(3)引入
import request from '@/utils/request'

6、登录加密

(1)新建crypto.js,代码如下:
import { AES, enc, mode, pad } from 'crypto-js'
const key = 'cccv613bbcabdcbaf322ff6fb37204bb'
/**
   * AES加密
   */
export function encryptByEnAES(data) {
  const Key = enc.Utf8.parse(key)
  const tmpAES = AES.encrypt(enc.Utf8.parse(data), Key, {
    mode: mode.ECB,
    padding: pad.Pkcs7
  })
  return tmpAES.toString()
}

/**
   * AES解密
   */

export function encryptByDeAES(data) {
  const Key = enc.Utf8.parse(key)
  const tmpDeAES = AES.decrypt(data, Key, {
    mode: mode.ECB,
    padding: pad.Pkcs7
  })
  return tmpDeAES.toString(enc.Utf8)
}
(2)引入
import { encryptByEnAES } from '@/utils/crypto';
const aesBody = encryptByEnAES(JSON.stringify(this.loginForm))

五、其他

1、运行项目后自动在浏览器中打开

(1)打开config==>index.js
(2)module.exports配置中找到autoOpenBrowser,默认设置的是false,改为true
(3)保存后重启项目