写一个简易的java项目(二) Vue+ElementUI+axios +打包放到项目下

之前写过一个Vue 学习笔记 细节就不多写了

1. 进入CMD

 

 2.创建项目

vue init webpack

 vs code下:

 

 调整端口避免冲突:

 

 到这里是回顾;

 

 ********************************

ElementUI:

用elementUI吧: 官网文档参考:https://element.eleme.cn/#/zh-CN/component/installation

安装一下按照官网:

npm i element-ui -S

然后引入

 

随便写几个按钮测试一下

看一下页面

 》》》》》》》》》

 axios :安装引入可参考:https://www.kancloud.cn/yunye/axios/234845 

main.js

 router 路由加上自己的页面

 然后随便从elmentUi官网粘贴了一个表格用来测试

 

 下面通过axios 访问自己的后台 为了方便我在自己的表中也加了date字段用于展示 实体中也做了相应的改动。先看一下后台查询结果。

 

 现在需要把显示的数据改成后台返回的数据。因为前后台的端口号不同 所以我们需要先解决跨域问题。config 下的index,js

 代码:

proxyTable: {
      '/api': {
        target: 'http://localhost:8091',//设置你调用的接口域名和端口号 别忘了加http
        changeOrigin: true,//如果需要跨域
        pathRewrite: {
          '^/api': '/',
        }
      }
    },

首先把原有的数据注释掉 写一个mounted 调用 axios 方法获取数据赋值给 tableData

 

 页面

》》》》》》》》》》 

点击编辑 加个弹窗吧 。。页面html

 ElementUI 官网复制一个弹窗。在里面加了一个时间选择器和input。

 代码:

<el-dialog title="编辑" :visible.sync="dialogVisible" width="30%" >
        <el-form ref="form" :model="form" label-width="80px">
          <el-form-item label="名称">
            <el-input v-model="form.name" placeholder="请输入名称"></el-input>
          </el-form-item>
          <el-form-item label="时间">
            <el-col :span="11">
              <el-date-picker type="datetime" placeholder="选择日期" value-format="yyyy-MM-dd HH:mm:ss" v-model="form.date" style="width: 100%;"></el-date-picker>
            </el-col>
          </el-form-item>
      </el-form>
    <span slot="footer" class="dialog-footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="save">保存</el-button>
    </span>
  </el-dialog>

点击编辑触发弹窗:

 点击保存:

 代码:

save () {
      this.dialogVisible = false
      let hello = new FormData()
      hello.append('id', this.form.id)
      hello.append('name', this.form.name)
      hello.append('date', this.form.date)
      this.$http.post('/api/hello/update', hello).then(
        response => {
          console.log(response)
        }
      )
    }
View Code

后台就不多写了 调用 mybatis-plus 的方法即可

serviceImpl:

 

 

 

 

 

 》》》》》》》

代码就写到这里 开始打包 npm run build

 

 放到项目下

 

 

 

 页面:

###  问题  ##

1. post 请求的时候参数发现太麻烦

    这是可以安装qs 给axios 做一个简单的封装 在做post请求时用  qs.stringify(data) 传参 

 main.js的改动

2. 发现生产环境和部署环境调用的url 有差异

这时需要配置config 下 prod.env.js 把正式的url 写进去

 代码:

'use strict'
module.exports = {
  NODE_ENV: '"production"',
  BASE_API:'"http://localhost:8091"'
}

这里是axios.js内部

 

const host = process.env.NODE_ENV === 'development' ? '/api/' : '/'// 根据 process.env.NODE_ENV 的值判断当前是什么环境

那我们现在的调用就可以改成这样了 是不是简单了很多

 

 代码:

// 引入模块
import axios from 'axios'
import qs from 'qs'

// 是否允许跨域
axios.defaults.withCredentials = true

const host = process.env.NODE_ENV === 'development' ? '/api/' : '/'// 根据 process.env.NODE_ENV 的值判断当前是什么环境

// axios初始化:延迟时间,主路由地址
let instance = axios.create({
  baseURL: host,
  timeout: 10000
})

// 设置拦截器
instance.interceptors.request.use(function (config) {
  // 在发送请求之前做某事
  return config
}, function (error) {
  // 请求错误时做些事
  return Promise.reject(error)
})
// 响应拦截器
instance.interceptors.response.use(function (response) {
  // 对响应数据做些事
  return response
}, function (error) {
  // 请求错误时做些事
  return Promise.reject(error)
})

// 是否销毁拦截器
// 1.给拦截器起个名称 var myInterceptors = instance.interceptors.requesst.use();
// 2.instance.interceptors.request.eject(myInterceptor);

// 请求成功的回调
function checkStatus (res) {
  // 请求结束成功
  if (res.status === 200 || res.status === 304) {
    return res.data
  }
  return {
    code: 0,
    msg: res.data.msg || res.statusText,
    data: res.statusText
  }
}
// 请求失败的回调
function checkCode (res) {
  if (res.code === 0) {
    throw new Error(res.msg)
  }
  return res
}
// 模块化导出
export default {
  get (url, params) {
    if (!url) return
    return instance({
      method: 'get',
      url: url,
      params,
      timeout: 30000
    }).then(checkStatus).then(checkCode)
  },
  post (url, data) {
    if (!url) return
    return instance({
      method: 'post',
      url: url,
      data: qs.stringify(data),
      timeout: 30000
    }).then(checkStatus).then(checkCode)
  },
  postFile (url, data) {
    if (!url) return
    return instance({
      method: 'post',
      url: url,
      data
    }).then(checkStatus).then(checkCode)
  }
}
View Code

 

 

 

 

 

 

 

 

 

 

@

 

posted @ 2020-04-15 16:29  DarGi  阅读(527)  评论(0编辑  收藏  举报