基于vuecli3的后台项目开发(一搭建基本内容)

最近公司启动一个后台项目开发,暂时分配给我一个人
要求是使用vue,剩下的就是我个人的选择要求了

一.搭建环境

搭建环境的方法有很多,我使用的是vuecli3通过vue ui中,可视化界面搭建
启示时安装了
vue-router vuex less axios vue-axios
xlsx file-saver script-loader (这三个是导出excel用)
vue-cli-plugin-element (element插件,配置成全局的)
@vue/cli-plugin-eslint (好像是错误校验有关,设置的标准的)

二.基本配置

参考https://www.jianshu.com/p/adc33ac846f9

1.新建文件夹
新建api文件夹,config文件夹,utils文件夹,

2.多环境运行

//.env.dev
NODE_ENV = 'dev'
VUE_APP_MOBILE_URL= 'https://mobilemall-test.XXXX.com'
VUE_APP_TEST_URL  = 'http://www.api.com'
//.env.prod
NODE_ENV = 'prod'
VUE_APP_MOBILE_URL= 'https://mobilemall.XXXX.com'
VUE_APP_TEST_URL  = 'http://www.api.com'
//package.json
  "scripts": {
    "lint": "vue-cli-service lint",
    "build-dev": "vue-cli-service build --mode dev",
    "build-prod": "vue-cli-service build --mode prod",
    "serve-dev": "vue-cli-service serve --mode dev",
    "serve-prod": "vue-cli-service serve --mode prod"
  },

3.配置axios

(1)配置vue-axios 在main.js中

import axios from 'axios'
import VueAxios from 'vue-axios'
Vue.use(VueAxios, axios)

(2)在utils文件夹中新建mobileFetch.js和testFetch.js(有一个域名创建一个js)
并且对登录和权限方面进行控制

// 创建axios 实例
const service = this.axios.create({
  baseURL: process.env.VUE_APP_MOBILE_URL,
  timeout: 10000 // 请求超时时间
});

// request 拦截器
service.interceptors.request.use(
  config => {
    // 这里可以自定义一些config 配置
    return config;
  },
  error => {
    //  这里处理一些请求出错的情况
    Promise.reject(error);
  }
);

// response 拦截器
service.interceptors.response.use(
  response => {
    const res = response.data;
    // 这里处理一些response 正常放回时的逻辑
    return res;
  },
  error => {
    // 这里处理一些response 出错时的逻辑
    return Promise.reject(error);
  }
);

export default service;

(3)api请求配置
api中建立order文件夹,然后创建order.js文件

import mobileFetch from "@/utils/mobileFetch"; //引入mobileFetch拦截器,对应的域名是https://mobilemall.XXXX.com
import testFetch from "@/utils/testFetch"; //引入testFetch拦截器,对应的域名是http://www.api.com
export default {
  // 登录
  testApi(data) {
    return mobileFetch({
      url: "/mobile/homecol/getHomeColList",
      method: "post",
      data
    });
  }
};

运行后报错1


image.png

解决办法

//.eslintrc.js
 rules: {
    "no-console": process.env.NODE_ENV === "prod" ? "error" : "off",
    "no-debugger": process.env.NODE_ENV === "prod" ? "error" : "off",
    semi: 0
  },

报错2


image.png
rules: {
    "no-console": process.env.NODE_ENV === "prod" ? "error" : "off",
    "no-debugger": process.env.NODE_ENV === "prod" ? "error" : "off",
    semi: 0, //末尾不强制分号
    quotes: [1, "single"] //引号类型
  },

4.配置vuex
(1)配置

//store/index.js文件中
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    userInfo: {
    // name: 'Vuex',
    // img: 'https://raw.githubusercontent.com/taylorchen709/markdown-images/master/vueadmin/user.png'
    }
  },
  mutations: {
    login (state, user) {
      state.userInfo = user
    }
  },
  actions: {

  }
})

(2)使用
this.store.commit("login", userInfo); this.store.state.userInfo

image.png

5.vue-router按需加载

import Vue from "vue";
import VueRouter from "vue-router";

const Home = resolve => require(["@/views/Home.vue"], resolve);
const About = resolve => require(["@/views/About.vue"], resolve);
Vue.use(VueRouter);

const routes = [
  {
    path: "/",
    name: "home",
    component: Home
  },
  {
    path: "/about",
    name: "about",
    component: About
  }
];

const router = new VueRouter({
  routes
});

export default router;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354