一、创建项目
vue create customer
第一个默认,第二个自定义选择所需要的功能
二、引入依赖库
引入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
将页面搭建如下
四、编写增删改查代码
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 +
"¤t=" +
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
},
};
项目结构