iviewUI 前端静态页面实现增删改查分页
完整代码部分 (仅供参考哈):
<template>
<div>
<label prop="name"> 姓名: </label>
<Input v-model="companyName" id="pp" style="width: 120px" placeholder="请输入" />
<Button @click="search" type="primary" icon="ios-search">查询</Button>
<Button type="primary" @click="addBus" icon="ios-add-circle-outline">新增</Button>
<Table :columns="columns1" :data="data1" size="small" ref="table">
<template slot-scope="{ row }" slot="name">
<strong>{{ row.name }}</strong>
</template>
<template slot-scope="{ row, index }" slot="action">
<Button type="primary" size="small" style="margin-right: 5px" @click="show(index)">详情</Button>
<Button type="warning" style="margin-right: 5px" size="small" @click="editBus(row,index)">编辑</Button>
<!-- 前面的小图标会居中挡住文字 设置一下样式就好了 style="text-align:left" -->
<Poptip
style="text-align:left"
confirm
title="您确定要删除该信息?"
placement="left-end"
@on-ok="remove(index)"
@on-cancel="cancel1"
>
<Button type="error" size="small">删除</Button>
<!-- @click="remove(index)" -->
</Poptip>
</template>
</Table>
<Modal
v-model="handleModal"
title="新增一条数据"
@on-ok="ok"
@on-cancel="cancel"
:footer-hide="true"
:mask-closable="false"
width=""
@on-visible-change="handleReset('formValidate')"
>
<Form inline ref="formValidate" :model="formValidate" :label-width="" :rules="ruleValidate">
<FormItem label="姓名" prop="name">
<Input v-model="formValidate.name" placeholder="请输入姓名"></Input>
</FormItem>
<FormItem label="年龄" prop="age">
<Input v-model="formValidate.age" placeholder="请输入年龄"></Input>
</FormItem>
<FormItem label="爱好" prop="address">
<Input v-model="formValidate.address" placeholder="请输入你的爱好"></Input>
</FormItem>
<FormItem label="性别" prop="sex">
<Input v-model="formValidate.sex" placeholder="别不男不女"></Input>
</FormItem>
<FormItem>
<!-- 提交的单击事件 在下面的方法里面写好 -->
<Button type="primary" @click="handleSubmit('formValidate')">提交</Button>
<Button @click="handleReset('formValidate')" style="margin-left: 8px">重置</Button>
</FormItem>
</Form>
</Modal>
<!-- 分页控件 -->
<div style="margin: 10px;overflow: hidden">
<div style="float:left">
<Page
:total="dataCount"
:page-size="pageSize"
show-total
:current=""
@on-change="changepage"
></Page>
</div>
</div>
</div>
</template>
<script>
import { Script } from "vm";
let testData = {
histories: [
{
name: "老王",
age: ,
sex: "男",
address: "我喜欢吃苹果"
},
{
name: "张三",
age: ,
sex: "男",
address: "我喜欢吃炸鸡"
},
{
name: "张欧",
age: ,
sex: "男",
address: "我喜欢吃西瓜"
},
{
name: "张五",
age: ,
sex: "男",
address: "我喜欢吃阿弥光"
},
{
name: "国基",
age: ,
sex: "男",
address: "我喜欢吃烤鸭"
},
{
name: "老王",
age: ,
sex: "女",
address: "我喜欢吃苹果"
},
{
name: "张三",
age: ,
sex: "女",
address: "我喜欢吃炸鸡"
},
{
name: "张欧",
age: ,
sex: "女",
address: "我喜欢吃西瓜"
},
{
name: "张五",
age: ,
sex: "女",
address: "我喜欢吃阿弥光"
},
{
name: "国基",
age: ,
sex: "女",
address: "我喜欢吃烤鸭"
} ]
};
export default {
data() {
return {
// 这里需要设置原数据为空
// 好像跟实例化一样 不然会出错的
data1: [],
companyName: "",
// modal开始为false
handleModal: false, // 这个对应form里面的数据不能少 名字不规范我就不改了
// columns1 和formvalidate 里面的命名要一样 别乱了
formValidate: {
name: "",
flight: "",
begin: "",
destination: ""
},
// 分页 ajaxHistoryData: [],
// 初始化信息总条数
dataCount: ,
// 每页显示多少条
pageSize: ,
// 设置table的表头
columns1: [
{
title: "姓名",
key: "name"
},
{
title: "年龄",
key: "age"
},
{
title: "爱好",
key: "address"
},
{
title: "性别",
key: "sex"
},
{
title: "操作",
slot: "action",
width: ,
align: "center"
}
],
// 设置表格的数据
tableData: []
};
},
// 方法
methods: {
// 查找按钮
search() {
// 获取表格数据
var len = testData.histories;
// 设置一个空的数组
var arr = [];
// 循环遍历
for (var i in len) {
// if判断 如果文本框中的值等于表格中name的值 输出
if (len[i].name == this.companyName) {
arr.push(len[i]);
// 如果等于空就给他全部数据
} else if (this.companyName == "") {
this.data1 = testData.histories;
return;
}
}
// 将查找出来的数据给表格
this.data1 = arr;
},
// 新增按钮的单击事件
addBus() {
this.handleModal = true;
this.modalTitle = "新增";
},
// 新增数据
handleSubmit(name) {
var self = this;
self.$refs[name].validate(valid => {
if (valid) {
var params = JSON.parse(JSON.stringify(self.formValidate)); if (self.modalTitle == "新增") {
// 获取需要渲染到页面中的数据
self.$Message.success("新增成功!");
self.data1.push(params);
} else {
this.$set(self.data1, self.itemIndex, params);
self.$Message.success("修改成功!");
}
self.handleModal = false;
} else {
if (self.modalTitle == "新增") {
self.$Message.error("新增失败!");
} else {
self.$Message.error("修改失败!");
}
}
});
},
// 修改方法
editBus(item, index) {
this.handleModal = true;
this.modalTitle = "修改";
this.itemIndex = index;
this.formValidate = JSON.parse(JSON.stringify(item));
},
// 删除一条数据
remove(index) {
this.data1.splice(index, );
// on-click 方法 冒泡提示确定
this.$Message.success("删除成功");
},
cancel1() {
this.$Message.info("取消删除");
},
// 清除文本框 重置
handleReset(name) {
this.$refs[name].resetFields();
},
// 详情显示
show(index) {
this.$Modal.info({
title: "查看详情",
content: `姓名:${this.data1[index].name}<br>年龄:${this.data1[index].age}
<br>爱好:${this.data1[index].address}<br>性别:${this.data1[index].sex}
`
});
},
// 分页
handleListApproveHistory() {
// 保存取到的所有数据 this.ajaxHistoryData = testData.histories;
this.dataCount = testData.histories.length;
// 初始化显示,小于每页显示条数,全显,大于每页显示条数,取前每页条数显示
if (testData.histories.length < this.pageSize) {
this.data1 = this.ajaxHistoryData;
} else {
this.data1 = this.ajaxHistoryData.slice(, this.pageSize);
}
},
changepage(index) {
this.page = index;
var _start = (index - ) * this.pageSize;
var _end = index * this.pageSize;
this.data1 = this.ajaxHistoryData.slice(_start, _end);
} }, // 这个应该是加载事件 加载页面的时候就调用
// mounted() {
// // 页面一加载就将数据给出给表格
// this.data1 = testData.histories;
// },
created() {
this.handleListApproveHistory();
} };
</script> <style>
</style>
iviewUI 前端静态页面实现增删改查分页的更多相关文章
- SpringMVC4+MyBatis3+SQLServer 2014 整合(包括增删改查分页)
前言 说起整合自然离开ssm,我本身并不太喜欢ORM,尤其是MyBatis,把SQL语句写在xml里,尤其是大SQL,可读性不高,出错也不容易排查. 开发环境 idea2016.SpringMVC4. ...
- node-express项目的搭建并通过mongoose操作MongoDB实现增删改查分页排序(四)
最近写了一个用node来操作MongoDB完成增.删.改.查.排序.分页功能的示例,并且已经放在了服务器上地址:http://39.105.32.180:3333. Mongoose是在node.js ...
- OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)
公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...
- 项目二:品优购 第二天 AngularJS使用 brand商品页面的增删改查
品优购电商系统开发 第2章 品牌管理 传智播客.黑马程序员 1.前端框架AngularJS入门 1.1 AngularJS简介 AngularJS 诞生于2009年,由Misko Hevery 等人 ...
- Java简单示例-用户登录、单个页面的增删改查及简单分页
index.html -登录->stulist.jsp (index.html传递到LoginServlet,进行登录检测及写入session,NO返回index.html界面,OK 跳转到s ...
- go+mysql实现页面的增删改查练习
原文地址:http://www.niu12.com/article/35 初次学go,在了解一些基础之后就开始做一个用户的增删改查来回顾知识,有很多数据验证和安全漏洞并没有考虑,只当作联系 前提:下载 ...
- Hibernate全套增删改查+分页
1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...
- graphql 数据增删改查分页及关联操作(三)
说明: 接第二篇文章,代码也是在第二篇文章之上 本文只是针对mondodb来操作 一.添加相关的包 yarn add Mongoose 二.初始化Mongodb 修改server.ts 导入 impo ...
- Django图书管理系统(前端对数据库的增删改查)
图书管理系统 出版社的管理 源码位置:https://gitee.com/machangwei-8/learning_materials/tree/master/%E9%A1%B9%E7%9B%AE/ ...
随机推荐
- pip安装模块使用国内镜像源加速安装
今天在安装Python模块matplotlib的时候,一直安装不成功,老是提示“socket.timeout: The read operation timed out”或者“Read timed o ...
- Win平台下窗口操作(Unity)
Unity发布在Win平台时, 可以通过user32.dll的方式与Win API通信, 最小化窗口代码: public static class DllImports { private const ...
- Scala比较器---Ordered与Ordering
1.Ordered 和 Ordering Scala提供两个特质(trait)Ordered与Ordering用于比较.其中,Ordered混入(mix)Java的Comparable接口,而Orde ...
- 2018年蓝桥杯B组C/C++决赛题目
自己的博客排版,自我感觉略好一点. 先放上题目. 点击查看2018年蓝桥杯B组C/C++决赛题目题解 1.换零钞 x星球的钞票的面额只有:100元,5元,2元,1元,共4种. 小明去x星旅游, ...
- 曹玉中-201871010105《面向对象程序设计(java)》第6-7周学习总结
曹玉中-201871010105<面向对象程序设计(java)>第6-7周学习总结 项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.c ...
- Nginx配置参数中文详细说明
#定义Nginx运行的用户和用户组user www www;##nginx进程数,建议设置为等于CPU总核心数.worker_processes 8;##全局错误日志定义类型,[ debug | in ...
- 题解:[ZJOI2014]璀灿光华
原题链接 OJ 题号 洛谷 3342 loj 2203 bzoj 3619 题目描述 金先生有一个女朋友没名字.她勤劳勇敢.智慧善良.金先生很喜欢她.为此,金先生用\(a^3\)块\(1 \times ...
- JDOJ 1790: 高精度A-B
JDOJ 1790: 高精度A-B JDOJ传送门 洛谷 P2142 高精度减法 洛谷传送门 题目描述 高精度减法 输入格式 两个整数a,b(第二个可能比第一个大) 输出格式 结果(是负数要输出负号) ...
- 【redis】安装redis
1.什么是redis? 非关系型数据库 2.为什么用redis? 非关系型数据库的一些优势,我这里用于缓存 3.怎么用redis? 安装,配置,用 4.怎么安装? 下载:http://download ...
- nginx配置代理时参数说明