1、使用vue初始化项目

vue create msm-demo  #创建项目

npm run serve    #部署

2、更改public文件夹下面的index文件,只留下

<div id="app"></div>

3、创建配置vue.config.js
module.exports = {
devServer: {
port: 8888, //端口号,如果端口号占用,会自动提升1
host: "localhost", //主机名,127.0.0.1,真机:0.0.0.0
https: false, //协议
open: false, //启动服务时自动打开浏览器访问 }, lintOnSave: false, //关闭格式检查
productionSourceMap: false, // 打包时不会生成.map 文件,加快打包速度
}

4、整合第三方库

1、安装axios,处理异步请求

npm i -S axios

2、安装pubsub-js,实现非父子组件间通信

npm i -S  pubsub-js

3、查看package.json中是否有对应依赖


5、整合ElementUI

1、npm安装:

npm i element-ui -S

2、编辑main.js

import Vue from "vue";
//引入组件库
import ElementUI from 'element-ui';
//引入样式
import 'element-ui/lib/theme-chalk/index.css'; import App from "./App.vue";
import router from "./router"; //使用ElementUI
Vue.use(ElementUI); //报错是否全,开发环节位false,生产环节为true
Vue.config.productionTip = process.env.NODE_ENV === 'production'; //开发环境 development,生产环境 production
console.log(process.env.NODE_ENV) new Vue({
router,
render: h => h(App)
}).$mount("#app");

6、Axios封装和跨域问题

1、封装Axios对象  github:https://github.com/axios/axios

(自己封装的Axios在后续可以使用axios中提供的拦截器)

  1、在src目录下创建utils目录及utils下面创建request.js文件,自己创建axios对象

// 导入axios
import axios from 'axios' // 原来axios发送请求,在public文件夹下的文件可以不指定public,/db.json默认查找public文件夹下的文件
// axios.get('/db.json').then(response => {
// const data = response.data
// console.log(data)
// }) // 自己创建axios对象
const request = axios.create({
//基础路径
baseURL: '/',
timeout: 5000 //请求超时
}) //使用自定义的axios对象发送请求
// request.get('/db.json').then(response => {
// console.log(response.data)
// }) // 请求拦截器
//使用自定义的axios对象
request.interceptors.request.use(config => {
// 请求拦截
},err =>{
// 出现异常
// 使用ES6的语法
return Promise.reject(error);
}) // 响应拦截器
request.interceptors.response.use(response =>{
// response.data
return response
},error =>{
return Promise.reject(error);
}) // Add a request interceptor
// axios.interceptors.request.use(function (config) {
// // Do something before request is sent
// return config;
// }, function (error) {
// // Do something with request error
// return Promise.reject(error);
// }); // // Add a response interceptor
// axios.interceptors.response.use(function (response) {
// // Any status code that lie within the range of 2xx cause this function to trigger
// // Do something with response data
// return response;
// }, function (error) {
// // Any status codes that falls outside the range of 2xx cause this function to trigger
// // Do something with response error
// return Promise.reject(error);
// }); // 导出自定义创建的axios对象,导出后别人就可以使用此对象
export default request

2、在src文件夹下创建api文件夹,api文件夹放调用api接口的文件,src可用@表示,哪个组件要引用对应的api,就可以直接从api文件夹中进行api的引用

/api/test.js:

import request from '@/utils/request'

const BASE_URL = '/dev-api'

// 这里直接调用对应的方法发送请求
// request.get('/db.json').then(response => {
// console.log(response.data)
// }) //测试2,以对象配置的方式进行指定请求方式
//开发过程中,一般采用这种方法
request({
method: 'get',
url: BASE_URL + '/db.json'
}).then(response =>{
console.log('get2',response.data)
}) //导出一个默认对象
export default {
//定义方法
getList() {
//返回一个对象
const req = request({
method: 'get',
url: BASE_URL + 'db.json'
})
return req
}
}

/components/Helloworld.vue:调用接口

import testApi from '@/api/test'

export default {

  data() {
return {
list: []
}
}, created() {
this.fetchData()
},
methods: {
fetchData() {
testApi.getList().then(response => {
console.log('get3',response.data)
this.list = response.data
})
}
},

3、跨域现象:

前后端分离时,前端和后端API服务器可能不在同一台主机上,就存在跨域问题,浏览器限制了跨域访问

同源策略:是指协议,域名,端口都要相同,其中有一个不同都会产生跨域

解决开发环境跨域问题:

  配置代理https://cli.vuejs.org/zh/config/#devserver:通过 vue.config.js 中的 devServer.proxy 选项来配置。

proxy: {    //开发环境代理配置
// 配置前缀
'/dev-api': {
// 目标服务器地址,代理访问 http://localhost:8001
target: 'http://localhost:8001',
changeOrigin: true, //开启代理转发
pathRewrite: {
// /dev-api/db.json 最终会转发到http://localhost:8001/db.json
'^/dev-api': '', //此设置将请求地址前缀 /dev-api 替换为空
}
}
}

7、配置不同环境 常量值

https://cli.vuejs.org/zh/guide/mode-and-env.html

# 只有以 VUE_APP_ 开头的变量会被 webpack 静态嵌入到项目中进行使用 process.env.VUE_APP_XXXX

分别配置.env.development和.env.production

.env.development:

# 目标服务接口地址,这个地址时按照自己环境进行配置,添加或者更改配置后,需要重新启动服务
VUE_APP_SERVICE_URL = 'http://localhost:8001' # 开发环境的前缀
VUE_APP_BASE_API = '/dev-api'

.env.production:

# 只有以 VUE_APP_ 开头的变量会被 webpack 静态嵌入到项目中进行使用

VUE_APP_BASE_API = '/pro-api'

调用例子:

proxy: {    //开发环境代理配置
// 配置前缀
// '/dev-api': {
[process.env.VUE_APP_BASE_API]: {
// 目标服务器地址,代理访问 http://localhost:8001
target: process.env.VUE_APP_SERVICE_URL,
changeOrigin: true, //开启代理转发
pathRewrite: {
// /dev-api/db.json 最终会转发到http://localhost:8001/db.json
// '^/dev-api': '', //此设置将请求地址前缀 /dev-api 替换为空
['^' + [process.env.VUE_APP_BASE_API]]: ''
}
}
}

Vuejs实战项目步骤一的更多相关文章

  1. Vuejs实战项目四:权限校验

    路由跳转参考文档:https://router.vuejs.org/zh/guide/advanced/navigation-guards.html 在/src下创建permission.js进行权限 ...

  2. Vuejs实战项目五:数据列表

    1.在EasyMock 中添加数据列表模拟接口 请求url:/suyuan/list 请求方式:get 描述:数据列表 mock.js配置: 例: { "code": 2000, ...

  3. Vuejs实战项目三:退出系统功能实现

    1.创建Mockjs接口 method:post url:/user/logout 描述:退出系统 response: { "code": 2000, //状态码 "fl ...

  4. Vuejs实战项目:登陆页面

    1.在view文件夹下创建login文件夹,创建index.vue:代表登录的组件 配置router.js,导入登录组件 import Vue from "vue"; import ...

  5. 前后端分离之vue2.0+webpack2 实战项目 -- webpack介绍

    webpack的一点介绍 Webpack 把任何一个文件都看成一个模块,模块间可以互相依赖(require or import),webpack 的功能是把相互依赖的文件打包在一起.webpack 本 ...

  6. vue+websocket+express+mongodb实战项目(实时聊天)

    继上一个项目用vuejs仿网易云音乐(实现听歌以及搜索功能)后,发现上一个项目单纯用vue的model管理十分混乱,然后我去看了看vuex,打算做一个项目练练手,又不想做一个重复的项目,这次我就放弃颜 ...

  7. .NET Core实战项目之CMS 第三章 入门篇-源码解析配置文件及依赖注入

    作者:依乐祝 原文链接:https://www.cnblogs.com/yilezhu/p/9998021.html 写在前面 上篇文章我给大家讲解了ASP.NET Core的概念及为什么使用它,接着 ...

  8. .NET Core实战项目之CMS 第五章 入门篇-Dapper的快速入门看这篇就够了

    写在前面 上篇文章我们讲了如在在实际项目开发中使用Git来进行代码的版本控制,当然介绍的都是比较常用的功能.今天我再带着大家一起熟悉下一个ORM框架Dapper,实例代码的演示编写完成后我会通过Git ...

  9. .NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

    写在前面 上面文章我给大家介绍了Dapper这个ORM框架的简单使用,大伙会用了嘛!本来今天这篇文章是要讲Vue的快速入门的,原因是想在后面的文章中使用Vue进行这个CMS系统的后台管理界面的实现.但 ...

随机推荐

  1. IDEA 安装lombok及使用

    1.File-Settings-Plugins-Brows Repositories-输入lombok-install 2.重启idea 3.添加maven依赖 <dependency> ...

  2. 查看linux的shhd端口号 netstat | grep sshd

    [root@iZ2zef51hufoaycipfxek8Z ~]# [root@iZ2zef51hufoaycipfxek8Z ~]# netstat | grep sshd [root@iZ2zef ...

  3. Redis单机和集群配置(版本在5.0后)

    摘抄并用于自己后查 单机版的配置: 1. 下载redis压缩包,然后解压缩文件(tar xzf): 2. 进入解压后的redis文件目录,编译redis源文件(make,没有c环境要gcc): 3. ...

  4. ansible 安装及基本使用

    1.yum 安装 yum -y install epel-releaseyum -y install ansible ansible 配置秘钥 ssh-keygen -t rsa #直接回车不用设置密 ...

  5. 【JZOJ3303】城市规划

    description 刚刚解决完电力网络的问题, 阿狸又被领导的任务给难住了. 刚才说过, 阿狸的国家有n 个城市, 现在国家需要在某些城市对之间建立一些贸易路线, 使得整个国家的任意两个城市都直接 ...

  6. thinkphp Mongo模型

    Mongo模型是专门为Mongo数据库驱动而支持的Model扩展,如果需要操作Mongo数据库的话,自定义的模型类必须继承Think\Model\MongoModel. Mongo模型为操作Mongo ...

  7. hdu6088 组合数+反演+拆系数fft

    题意:两个人van石头剪子布的游戏一共n盘,假设A赢了a盘,B赢了b盘,那么得分是gcd(a,b),求得分的期望*\(3^{2*n}\) 题解:根据题意很明显有\(ans=3^{n}*\sum_{a= ...

  8. /usr/lib/gcc/x86_64-linux-gnu/5/../../../x86_64-linux-gnu/crt1.o:在函数‘_start’中: (.text+0x20):对‘main’未定义的引用

    原因是新建了一个可执行的函数,里面却没有main函数,加上main函数即可

  9. hp笔记本在设置VT-x为启用模式后还是无法在VMware上开启CentOS虚拟机

    在h笔记本上,将VT-x设置为Enabled模式后,需要断开电源,拆下电池,然后再按住开机按钮10秒钟左右放开,再重新装上电池,接通电源即可.

  10. zuul隔离机制

    文章转载自:https://blog.csdn.net/farsight1/article/details/80078099 ZuulException REJECTED_SEMAPHORE_EXEC ...