vue+element搭建后台管理界面(支持table条件搜索)
- 代码地址(如果有帮助,请点个Star)
- vue:https://github.com/wwt729/ElementUIAdmin-master.git
- springboot后端:https://github.com/wwt729/managemail.git
- 相关技术
- vue2:https://cn.vuejs.org/v2/guide/
- element :基于vuejs2.0的ui组件库
- axios:向后台发送请求,https://www.kancloud.cn/yunye/axios/234845
- moment:时间格式化组件
- 流程
- 安装node,参考https://www.cnblogs.com/729log/p/6244450.html
- 使用淘宝NPM镜像:$ npm install -g cnpm --registry=https://registry.npm.taobao.org
- 安装 vue-cli VUE的脚手架工具:cnpm install vue-cli -g
- idea安装vue插件,并新建vue项目:new ->project 选择Static Web 选择vue.js,取项目名,一路next,有些选项需要选择yes/no,请参考下图
5.下载依赖并启动:cnpm install 和 cnpm run serve
3.主要代码介绍
1.搜索条件,启用 flex 布局,justify(排版方式):start[居左]、center[居中]、end[居右]、space-between、space-around
<el-row type="flex" class="row-bg" justify="end"> <el-col :span="4"> <el-select v-model="sendCount" clearable placeholder="请选择发送次数"> <el-option v-for="item in sendCountList" :key="item.key" :label="item.label" :value="item.key"> </el-option> </el-select> </el-col> <el-col :span="4"> <el-select v-model="mailStatusSNMP" clearable placeholder="请选择发送状态"> <el-option v-for="item in mailStatusList" :key="item.key" :label="item.label" :value="item.key"> </el-option> </el-select> </el-col> <el-col :span="2"> <el-button type="primary" icon="el-icon-search" @click="getmails()">搜索</el-button> </el-col> </el-row>
2.分页
<el-pagination background @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page.sync="currentPage" :page-sizes="[10, 20, 30, 50]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="total"> </el-pagination>
3.请求方法,使用qs封装参数,使用moment格式化时间
getmails () { let postData = this.$qs.stringify({ page:this.currentPage, rows:this.pageSize, status: this.mailStatusSNMP, sendCount: this.sendCount }); this.loading = true; this.$http({method:"post",url:'http://localhost:8086/mail/page',data:postData}).then((res) => { console.log(res.data); if (res.data == ''){ this.mails= []; this.total=0; }else { let chan=res.data.items.length; for (let i = 0; i < chan; i++) { if (res.data.items[i].status==0){ res.data.items[i].status="待发送"; res.data.items[i].sendTime=moment(res.data.items[i].sendTime).format("YYYY-MM-DD HH:mm:ss") }else if (res.data.items[i].status==1){ res.data.items[i].status="已发送"; res.data.items[i].sendTime=moment(res.data.items[i].sendTime).format("YYYY-MM-DD HH:mm:ss") } else if (res.data.items[i].status==2) { res.data.items[i].status="发送失败"; res.data.items[i].sendTime=moment(res.data.items[i].sendTime).format("YYYY-MM-DD HH:mm:ss") } } this.mails = res.data.items; this.total= res.data.total } }).catch((err) => { console.error(err) }) },
4.后端接受请求controller
@PostMapping("page") public ResponseEntity<PageResult<MailDTO>> querySpuPage( @RequestParam(defaultValue = "1") int page,//当前页 @RequestParam(defaultValue = "10") int rows,//每页条数 @RequestParam(value = "status",required = false)Integer status,//查询条件1 @RequestParam(value = "sendCount",required = false)Integer sendCount //查询条件2 ) { return ResponseEntity.ok(mailService.queryMailList(page,rows,status,sendCount)); }
模板参考:https://www.cnblogs.com/similar/p/10240341.html
一群人急匆匆地赶路,突然,一个人停了下来。旁边的人很奇怪:为什么不走了?停下的人一笑:走得太快,灵魂落在了后面,我要等等它。
vue+element搭建后台管理界面(支持table条件搜索)的更多相关文章
- vue+elementui搭建后台管理界面(8 同步/异步获取数据渲染table)
elementui已经封装好了 el-table 组件,只需要指定 data 数据源即可,因此通常在 vue 实例生命周期的 created 阶段,从数据库获取数据,再将返回的数据绑定到 data 如 ...
- vue+elementui搭建后台管理界面(6登录和菜单权限控制)
不同的权限对应不同的路由(菜单),同时侧边栏也根据权限异步生成,实现登录和鉴权思路如下: 登录:点击登录,服务器验证通过后返回一个 token ,然后存到 cookie,再根据 token 拉取用户权 ...
- vue+elementui搭建后台管理界面(7 vuex和mockjs的使用)
将权限管理应用到系统,首先做好登录, 点击登录按钮后,触发以下动作 vuex 中的 login 动作,设置 cookie vuex 中的 getuserinfo , 获取权限.用户名.头像等 由于目前 ...
- vue+elementui搭建后台管理界面(2首页)
1 会话存储 使用html5的 sessionStorage 对象临时保存会话 // 保存会话 sessionStorage.setItem('user', username) // 删除会话 ses ...
- vue+elementui搭建后台管理界面
1 会话存储 使用html5的 sessionStorage 对象临时保存会话 // 保存会话 sessionStorage.setItem('user', username) // 删除会话 ses ...
- vue+elementui搭建后台管理界面(1登录)
1 node环境安装 从 node官网下载安装包 2 vue-cli npm install vue-cli -g 3 新建项目 vue init webpack vue-project 可保持默认, ...
- vue+elementui搭建后台管理界面(5递归生成侧栏路由)
有一个菜单树,顶层菜单下面有多个子菜单,子菜单下还有子菜单... 这时候就要用递归处理 1 定义多级菜单 修改 src/router/index.js 的 / 路由 { path: '/', redi ...
- vue+elementui搭建后台管理界面(3侧边栏菜单)
上一节搭好了主框架,但是标签页和侧边栏只是分别展示了各自的菜单,如何将二者联动起来? 定义路由规则:当有 children 属性时,从 children 里取出 path 填充到侧边栏,如: { pa ...
- vue+elementui搭建后台管理界面(6登录和菜单权限控制[二])
根据权限计算路由的代码 /** * 通过meta.role判断是否与当前用户权限匹配 * @param roles * @param route */ function hasRoles (roles ...
随机推荐
- scrapy基础知识之 使用FormRequest.from_response()方法模拟用户登录:
通常网站通过 实现对某些表单字段(如数据或是登录界面中的认证令牌等)的预填充 使用Scrapy抓取网页时,如果想要预填充或重写像用户名.用户密码这些表单字段, 可以使用 FormRequest.fro ...
- 如何正确使用Profibus插头以及终端电阻
插头与终端电阻在Profibus通讯中有着非常重要的作用,它们使用起来非常简单,没有很多复杂的设置:但是正是由于使用简单,使得很多工程师在使用当中忽略了一些细节,导致很多通讯问题. 1 Profibu ...
- Oracle数据库----查询
--笛卡尔集select empno,ename, 员工表.deptno, 部门表.deptno, dname from 部门表, 员工表; --添加合适的条件,可以避免笛卡尔集,从而得到正确的多表查 ...
- Spring Cloud 之 Hystrix.
一.概述 在微服务架构中,我们将系统拆分成了很多服务单元,各单元的应用间通过服务注册与订阅的方式互相依赖.由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依 ...
- Java项目案例之--封装的实例
Java项目案例之---封装的实例 有一个专业类,有一个专业对象,专业名称:计算机科学与技术,专业编号:J001,专业年限:4,对年限添加约束,如果输入小于0,则默认为0,否则显示输入的值 有一个学生 ...
- java截取避免空字符丢失
1. 场景描述 数据后端是Hbase等nosql数据库,返回的数据以逗号分隔,java后端获取数据后,需要新增组装数据后再返回给前端. 2. 问题解决 2.1 问题定位 本来用的java的split进 ...
- restapi(1)- 文件上传下载服务
上次对restapi开了个头,设计了一个包括了身份验证和使用权限的restful服务开发框架.这是一个通用框架,开发人员只要直接往里面加新功能就行了.虽然这次的restapi是围绕着数据库表的CRUD ...
- Java调用方法参数究竟是传值还是传址?
之前阅读<Head First Java>的时候,记得里面有提到过,Java在调用方法,传递参数的时候,采用的是pass-by-copy的方法,传递一份内容的拷贝,即传值.举一个最简单的例 ...
- Flutter初体验--环境搭建
Fluter最近火了起来,它的有点很多,今天我做一篇在Windows下安装Flutter的教程. 一.下载 无论你要安装什么软件,都要先下载下来.我用的是SourceTree,地址: https ...
- Cesium 学习(二)所支持的模型数据类型,以及转换
1.Cesium所支持的模型数据类型 目前所知的有glTF.glb.bgltf等格式的模型数据: 想要了解glTF等的知识可以看一下https://www.cnblogs.com/fuckgiser/ ...