一、创建项目

vue create customer

第一个默认,第二个自定义选择所需要的功能

image-20200528050450353

二、引入依赖库

引入element-ui

npm install element-ui -S

引入异步请求需要的库vue-resource

npm install vue-resource

修改main.js

import Vue from 'vue'
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import VueResource from 'vue-resource'
import App from './App.vue'

Vue.use(ElementUI);
Vue.use(VueResource)

Vue.config.productionTip = false

new Vue({
  el: '#app',
  render: h => h(App)
});

三、使用UI框架搭建页面

选择要使用的UI

image-20200528053818095

将页面搭建如下

image-20200528053955231

image-20200528054140420

image-20200528054159681

四、编写增删改查代码

App.vue

<template>
  <div>
    <!-- 绑定visible.sync事件,是否显示新增页面 -->
    <el-dialog title="新增" :visible.sync="addFormVisible">
      <el-form ref="form" :model="form" label-width="80px">
        <el-form-item label="性别">
          <el-radio-group v-model="form.sex">
            <el-radio label="男"></el-radio>
            <el-radio label="女"></el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="姓名">
          <el-input v-model="form.name"></el-input>
        </el-form-item>
        <el-form-item label="手机">
          <el-input v-model="form.phone"></el-input>
        </el-form-item>
        <el-form-item label="邮箱">
          <el-input v-model="form.mail"></el-input>
        </el-form-item>

        <el-form-item>
          <!-- 绑定事件onSubmit,点击添加时触发添加方法 -->
          <el-button type="primary" @click="onSubmit">添加</el-button>
          <!-- 绑定事件click,取消关闭新增页面 -->
          <el-button @click="addFormVisible=false">取消</el-button>
        </el-form-item>
      </el-form>
    </el-dialog>

    <!-- 绑定visible.sync事件,是否显示修改页面 -->
    <el-dialog title="修改" :visible.sync="editFormVisibles">
      <el-form ref="form" :model="form" label-width="80px">
        <el-form-item label="性别">
          <el-radio-group v-model="form.sex">
            <el-radio label="男"></el-radio>
            <el-radio label="女"></el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="编号">
          <el-input :disabled="true" v-model="form.id"></el-input>
        </el-form-item>
        <el-form-item label="姓名">
          <el-input v-model="form.name"></el-input>
        </el-form-item>
        <el-form-item label="手机">
          <el-input v-model="form.phone"></el-input>
        </el-form-item>
        <el-form-item label="邮箱">
          <el-input v-model="form.mail"></el-input>
        </el-form-item>

        <el-form-item>
          <!-- 绑定事件onEdit,点击修改时触发修改方法 -->
          <el-button type="primary" @click="onEdit">修改</el-button>
          <!-- 绑定事件click,取消关闭修改页面 -->
          <el-button @click="editFormVisibles=false">取消</el-button>
        </el-form-item>
      </el-form>
    </el-dialog>

    <el-row>
      <!-- 绑定事件add,点击新增时触发新增方法 -->
      <el-button type="primary" @click="add" round>新增</el-button>
      <!-- 判断选中个数为1时,修改按钮可以使用 -->
      <el-button type="success" @click="edit" :disabled="idList.length==1?false:true" round>修改</el-button>
      <!-- 判断选中个数大于0时,删除按钮可以使用 -->
      <el-button type="danger" @click="del()" :disabled="idList.length>0?false:true" round>删除</el-button>
    </el-row>
    <!-- 将数据在表格显示出来,绑定事件selectionChange,选中时触发的方法 -->
    <el-table :data="tableData" @selection-change="selectionChange" stripe style="width: 100%">
      <el-table-column type="selection" width="55"></el-table-column>
      <el-table-column prop="id" label="编号"></el-table-column>
      <el-table-column prop="sex" label="性别"></el-table-column>
      <el-table-column prop="name" label="姓名"></el-table-column>
      <el-table-column prop="phone" label="手机"></el-table-column>
      <el-table-column prop="mail" label="邮箱"></el-table-column>
    </el-table>
    <!-- 官方文档绑定事件@current-change -->
    <!-- 总页数大于每页显示的数量才显示页码 -->
    <el-pagination
      v-if="page.total>page.size"
      background
      layout="prev, pager, next"
      @current-change="currentChange"
      :current-page="page.current"
      :page-size="page.size"
      :total="page.total"
    ></el-pagination>
  </div>
</template>

<script>
export default {
  data() {
    return {
      // 定义表格的数据
      tableData: [],
      // 定义页码的数据
      page: {
        // 当前页
        current: 1,
        // 每页显示数量
        size: 5,
        // 总页数
        total: 0
      },
      // 删除多选按钮ID数组
      idList: [],
      // 新增表单数据
      form: {
        id: "",
        name: "",
        sex: "男",
        phone: "",
        mail: ""
      },
      // 新增页面的默认值,false不显示
      addFormVisible: false,
      // 修改页面的默认值,false不显示
      editFormVisibles: false
    };
  },
  created: function() {
    // 页面加载时查询数据
    this.getData();
  },
  methods: {
    //通过ajax去请求后台数据,查询数据
    getData() {
      let url =
        "http://192.168.17.101:8080/customerInfo?size=" +
        this.page.size +
        "&current=" +
        this.page.current;
      // 需要引入npm install vue-resource,通过URL的拼接去请求后台的数据,并返回给前端
      this.$http.get(url).then(res => {
        let rs = JSON.parse(JSON.stringify(res.body));
        // 获取表格的数据
        this.tableData = rs.data.records;
        // 获取总页的数据
        this.page.total = rs.data.total;
      });
    },
    // 分页点击事件
    currentChange(current) {
      console.log(current + "分页点击事件");
      // 获取当前点击页数
      this.page.current = current;
      //重新获取后台数据给前端
      this.getData();
    },
    //  多选按钮选中事件
    selectionChange(selection) {
      // 选中一个的时候进行编辑,选中多个不能编辑
      if (selection.length == 1) {
        console.log("编辑");
        // 将选中的值赋值给编辑表单
        selection.forEach(element => {
          this.form.id = element.id;
          this.form.sex = element.sex;
          this.form.name = element.name;
          this.form.phone = element.phone;
          this.form.mail = element.mail;
        });
      }
      // 多选按钮删除事件,定义一个空的数组
      this.idList = [];
      // 将选中的ID添加到数组,删除事件需要的数据
      selection.forEach(element => {
        this.idList.push(element.id);
      });
      console.log(this.idList);
    },
    // 删除事件
    del() {
      if (this.idList.length > 0) {
        // 获取选中数据的ID,并转换成字符串,拼接URL后发送给后台
        let idList = this.idList.toString();
        let url = "http://192.168.17.101:8080/customerInfo?idList=" + idList;
        this.$http.delete(url).then(res => {
          // 转换后台返回的数据成JSON
          let rs = JSON.parse(JSON.stringify(res.body));
          console.log(rs.msg);
          //重新获取后台数据给前端
          this.getData();
        });
      }
    },
    // 打开新增界面时默认的值
    add() {
      this.form.id = "";
      this.form.sex = "男";
      this.form.name = "";
      this.form.phone = "";
      this.form.mail = "";
      this.addFormVisible = true;
    },
    // 新增数据
    onSubmit() {
      console.log(this.form);
      let url = "http://192.168.17.101:8080/customerInfo";
      let data = this.form;
      this.$http
        .post(url, {
          // 构建JSON数据,发送给后台
          sex: data.sex,
          name: data.name,
          phone: data.phone,
          mail: data.mail
        })
        .then(res => {
           // 转换后台返回的数据成JSON
          let rs = JSON.parse(JSON.stringify(res.body));
          console.log(rs.msg);
          // 关闭新增页面
          this.addFormVisible = false;
          // 重新获取后台数据给前端
          this.getData();
        });
    },
    // 点击修改按钮触发,弹出修改界面
    edit() {
      this.editFormVisibles = true;
    },
    // 修改界面,点击修改按钮触发,将选中表格行的数据赋值给修改框,然后发送给后台
    onEdit() {
      console.log(this.form);
      let url = "http://192.168.17.101:8080/customerInfo";
      let data = this.form;
      this.$http
        .put(url, {
          // 构建JSON数据,发送给后台
          id: data.id,
          sex: data.sex,
          name: data.name,
          phone: data.phone,
          mail: data.mail
        })
        .then(res => {
          // 转换后台返回的数据成JSON
          let rs = JSON.parse(JSON.stringify(res.body));
          console.log(rs.msg);
          // 关闭修改页面
          this.editFormVisibles = false;
          // 重新获取后台数据给前端
          this.getData();
        });
    }
  }
};
</script>

<style>
</style>

五、其它配置

在项目根目录创建vue.config.js可以修改IP地址、端口等。

module.exports = {
    devServer: {
        disableHostCheck: false,
        host: "0.0.0.0",
        port: 8081,
        https: false,
        hotOnly: false,
        proxy: null
    },
};

项目结构

image-20200528054459021