1. <!DOCTYPE html>
  2. <html >
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Demo</title>
  9. <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
  10. <style>
  11. .el-table-add-row {
  12. margin-top: 10px;
  13. width: 100%;
  14. height: 34px;
  15. border: 1px dashed #c1c1cd;
  16. border-radius: 3px;
  17. cursor: pointer;
  18. justify-content: center;
  19. display: flex;
  20. line-height: 34px;
  21. }</style>
  22. </head>
  23.  
  24. <body>
  25. <div id="app">
  26. <el-row>
  27. <el-col span="24">
  28. <el-table size="mini" :data="master_user.data" border style="width: 100%" highlight-current-row>
  29. <el-table-column type="index"></el-table-column>
  30. <el-table-column v-for="(v,i) in master_user.columns" :prop="v.field" :label="v.title" :width="v.width">
  31. <template slot-scope="scope">
  32. <span v-if="scope.row.isSet">
  33. <el-input size="mini" placeholder="请输入内容" v-model="master_user.sel[v.field]">
  34. </el-input>
  35. </span>
  36. <span v-else>{{scope.row[v.field]}}</span>
  37. </template>
  38. </el-table-column>
  39. <el-table-column label="操作" width="100">
  40. <template slot-scope="scope">
  41. <span class="el-tag el-tag--info el-tag--mini" style="cursor: pointer;" @click="pwdChange(scope.row,scope.$index,true)">
  42. {{scope.row.isSet?'保存':"修改"}}
  43. </span>
  44. <span v-if="!scope.row.isSet" class="el-tag el-tag--danger el-tag--mini" style="cursor: pointer;">
  45. 删除
  46. </span>
  47. <span v-else class="el-tag el-tag--mini" style="cursor: pointer;" @click="pwdChange(scope.row,scope.$index,false)">
  48. 取消
  49. </span>
  50. </template>
  51. </el-table-column>
  52. </el-table>
  53. </el-col>
  54. <el-col span="24">
  55. <div class="el-table-add-row" style="width: 99.2%;" @click="addMasterUser()"><span>+ 添加</span></div>
  56. </el-col>
  57. </el-row>
  58.  
  59. </div>
  60. <!-- import Vue before Element -->
  61. <script src="https://unpkg.com/vue@2.5.17/dist/vue.min.js"></script>
  62. <!-- import JavaScript -->
  63. <script src="https://unpkg.com/element-ui/lib/index.js"></script>
  64. <script>
  65. //id生成工具 这个不用看 示例而已 模拟后台返回的id
  66. var generateId = {
  67. _count: 1,
  68. get(){return ((+new Date()) + "_" + (this._count++))}
  69. };
  70. //主要内容
  71. var app = new Vue({
  72. el: "#app",
  73. data: {
  74. master_user: {
  75. sel: null,//选中行
  76. columns: [
  77. { field: "type", title: "远程类型", width: 120 },
  78. { field: "addport", title: "连接地址", width: 150 },
  79. { field: "user", title: "登录用户", width: 120 },
  80. { field: "pwd", title: "登录密码", width: 220 },
  81. { field: "info", title: "其他信息" }
  82. ],
  83. data: [],
  84. },
  85. },
  86. methods: {
  87. //读取表格数据
  88. readMasterUser() {
  89. //根据实际情况,自己改下啊
  90. app.master_user.data.map(i => {
  91. i.id = generateId.get();//模拟后台插入成功后有了id
  92. i.isSet=false;//给后台返回数据添加`isSet`标识
  93. return i;
  94. });
  95. },
  96. //添加账号
  97. addMasterUser() {
  98. for (let i of app.master_user.data) {
  99. if (i.isSet) return app.$message.warning("请先保存当前编辑项");
  100. }
  101. let j = { id: 0, "type": "", "addport": "", "user": "", "pwd": "", "info": "", "isSet": true, "_temporary": true };
  102. app.master_user.data.push(j);
  103. app.master_user.sel = JSON.parse(JSON.stringify(j));
  104. },
  105. //修改
  106. pwdChange(row, index, cg) {
  107. //点击修改 判断是否已经保存所有操作
  108. for (let i of app.master_user.data) {
  109. if (i.isSet && i.id != row.id) {
  110. app.$message.warning("请先保存当前编辑项");
  111. return false;
  112. }
  113. }
  114. //是否是取消操作
  115. if (!cg) {
  116. if (!app.master_user.sel.id) app.master_user.data.splice(index, 1);
  117. return row.isSet = !row.isSet;
  118. }
  119. //提交数据
  120. if (row.isSet) {
  121. //项目是模拟请求操作 自己修改下
  122. (function () {
  123. let data = JSON.parse(JSON.stringify(app.master_user.sel));
  124. for (let k in data) row[k] = data[k];
  125. app.$message({
  126. type: 'success',
  127. message: "保存成功!"
  128. });
  129. //然后这边重新读取表格数据
  130. app.readMasterUser();
  131. row.isSet = false;
  132. })();
  133. } else {
  134. app.master_user.sel = JSON.parse(JSON.stringify(row));
  135. row.isSet = true;
  136. }
  137. }
  138. }
  139. });
  140. </script>
  141. </body>
  142.  
  143. </html>

ElementUI table 点击编辑按钮进行编辑实现示例的更多相关文章

  1. element-ui table 点击分页table滚动到顶部

    在做项目中,碰到一个问题,table加了固定头,内容可滚动,当滚到table底边时,点击分页后还在底边 解决方法:设置table的 ref='multipleTable' //切换分页的方法加上下面这 ...

  2. Ubuntu 18.04中截图工具Shutter的编辑按钮不可用的解决办法

    Shutter是一个由第三方提供的在Ubuntu上运行的截图工具,相对于系统自带的截图工具(默认可通过Ctrl + Shift + Print快捷键启动截图),最大的优点就是可以即时对图片进行编辑,在 ...

  3. corethink功能模块探索开发(十四)后台编辑按钮

    效果图: 1.添加下图55&58行代码 2.实现edit方法 位于Equip/Admin/DeviceRepaireAdmin.class.php中 public function edit( ...

  4. 【jquery】【ztree】节点添加自定义按钮、编辑和删除事件改成自己定义事件

    setting添加 edit: { drag: { isCopy: false, isMove: true }, enable: true,//设置是否处于编辑状态 showRemoveBtn: sh ...

  5. Odoo 配置快速创建编辑按钮

    对于Man2one类型的数据,我们知道,form view中总会显示出一个尾巴似的"create and edit"和一个快速创建的机制,有时候业务人员一不小心就容易创建一个新的行 ...

  6. odoo开发笔记 -- odoo10 视图界面根据字段状态,动态隐藏创建&编辑按钮

    场景描述: 解决方式: 网络搜索,vnsoft_form_hide_edit 找到了这个odoo8的模块, odoo10语法和视图界面有新的变化,所以需要修改一些地方,感兴趣的小伙伴可以对比下两个代码 ...

  7. 点击EditText可编辑,点击其他地方不可编辑

    我是在Fragment中实现的,在网上查了,有的说要回调Activity的onTouch事件,通过实验直接在Fragment中即可.如下: 我的EditText在ScrollView,因为Scroll ...

  8. 在使用element-ui搭建的表格中,实现点击"定位"按钮后,屏幕滚动到对应行的位置

    背景: 一个后台管理系统,当管理员登录之后,会存在一个自己的id值, 在一个表格中,当点击"定位"按钮后,屏幕滚动到拥有管理员id的这一行,并且给设置一个高亮的背景 相关知识点: ...

  9. RFS_点击button按钮之后,RFS出现卡死的问题

    [html代码] <html> <head> <title> 主窗口 </title> </head> <body> <d ...

随机推荐

  1. python中的局部变量和全局变量

  2. Spring Cloud第三篇 | 搭建高可用Eureka注册中心

    ​ ​本文是Spring Cloud专栏的第三篇文章,了解前两篇文章内容有助于更好的理解后面文章: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring ...

  3. 对于web前端的理解

    对于web前端的理解 其实写这篇文章的首要目的是为了准备一道面试题——你对前端的看法是什么?本文不会仅从技术角度去考虑这个问题,还会依据这个社会的变革去讨论这个问题.本文仅代表个人观点,不喜勿喷. W ...

  4. SpringBoot系列之集成jsp模板引擎

    目录 1.模板引擎简介 2.环境准备 4.源码原理简介 SpringBoot系列之集成jsp模板引擎 @ 1.模板引擎简介 引用百度百科的模板引擎解释: 模板引擎(这里特指用于Web开发的模板引擎)是 ...

  5. mac本地搭建svn

    mac系统默认已经安装了svn,我们只需要配置并开启就可以了. 首先我们可以验证一下是否安装了svn,打开终端,输入命令 svnserve —version

  6. Erlang/Elixir精选-第2期(20191209)

    Spot The Discrepancies with Dialyzer for Erlang. 如何在大型Erlang项目中从零开始一步步践行Dialyzer. Which companies ar ...

  7. 一文了解Nuget的使用

    Nuget介绍 官网定义:NuGet是.NET的软件包管理器(免费).NuGet客户端工具提供了生成和使用软件包的能力.NuGet Gallery 是所有软件包作者和消费者都使用的中央软件包存储库. ...

  8. 曹工杂谈:Spring boot应用,自己动手用Netty替换底层Tomcat容器

    前言 问:标题说的什么意思? 答:简单说,一个spring boot应用(我这里,版本升到2.1.7.Release了,没什么问题),默认使用了tomcat作为底层容器来接收和处理连接. 我这里,在依 ...

  9. lodash.memoize

    目录 _.memoize(func, [resolver]) 举例1: 获取J(1000000)的值 举例2: 斐波那契数列F(1000)的值 _.memoize(func, [resolver]) ...

  10. python数学工具(一)

    python  数学工具包括: 1.函数的逼近 1.1.回归 1.2.插值 2.凸优化3.积分4.符号数学 本文介绍函数的逼近的回归方法 1.作为基函数的单项式 对函数 的拟合 首先定义函数并且可视化 ...