Vue.js实现表格动态增加删除的方法(附源码下载)


Posted in Javascript onJanuary 20, 2017

Vue.js

Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的。相比于Angular.js,Vue.js提供了更加简洁、更易于理解的API,使得我们能够快速地上手并使用Vue.js。

先来看看实现的效果:

Vue.js实现表格动态增加删除的方法(附源码下载)

Vue.js实现表格动态增加删除的方法(附源码下载)

下面的例子会用到bootstrap.min.css以及vue.js,都可以从网上下载(文末有完整源码下载提供)。

实例 源码

<!DOCTYPE html> 
<html lang="en"> 
<head> 
 <meta charset="UTF-8"> 
 <title>Vue.js小demo</title> 
 <link rel="stylesheet" href="css/bootstrap.min.css"> 
</head> 
<body> 
<!-- 这是我们的view --> 
<div class="col-md-6"> 
 <div class="panel panel-default" id="app" > 
  <div class="panel-body form-horizontal"> 
   <div class="form-group"> 
    <label class="col-md-2 control-label">Name:</label> 
    <div class="col-md-10"> 
     <input type="text" class="form-control" v-model="newPerson.name"/> 
    </div> 
   </div> 
   <div class="form-group"> 
    <label class="col-md-2 control-label">Age:</label> 
    <div class="col-md-10"> 
     <input type="text" class="form-control" v-model="newPerson.age"> 
    </div> 
   </div> 
   <div class="form-group"> 
    <label class="col-md-2 control-label">Sex:</label> 
    <div class="col-md-10"> 
     <select class="form-control" v-model="newPerson.sex"> 
      <option value="Male">Male</option> 
      <option value="Female">Female</option> 
     </select> 
    </div> 
   </div> 
   <div class="form-group"> 
    <label for=""></label> 
    <button class="col-md-offset-2" @click="createPerson">Create</button> 
   </div> 
  </div>  
  <div class="panel-body"> 
 
   <table class="table text-center"> 
    <thead> 
     <tr > 
      <th class="text-center">Name</th> 
      <th class="text-center">Age</th> 
      <th class="text-center">Sex</th> 
      <th class="text-center">Delete</th> 
     </tr> 
    </thead> 
    <tbody> 
     <tr v-for="person in people"> 
      <td>{{ person.name }}</td> 
      <td>{{ person.age }}</td> 
      <td>{{ person.sex }}</td> 
      <td><button @click="deletePerson($index)">Delete</button></td> 
     </tr> 
    </tbody> 
   </table> 
  </div> 
 </div> 
</div> 
</body> 
<script src="js/vue.js"></script> 
<script> 
//创建一个Vue实例或"ViewModel",它连接view与model 
 var vm = new Vue({ 
   el: '#app', 
   data: { 
    newPerson: { 
     name: '', 
     age: 0, 
     sex: 'Male' 
    }, 
    people: [{ 
     name: 'Jack', 
     age: 30, 
     sex: 'Male' 
    }, { 
     name: 'Bill', 
     age: 26, 
     sex: 'Male' 
    }, { 
     name: 'Tracy', 
     age: 22, 
     sex: 'Female' 
    }, { 
     name: 'Chris', 
     age: 36, 
     sex: 'Male' 
    }] 
   }, 
   methods:{ 
    createPerson: function(){ 
     this.people.push(this.newPerson); 
     // 添加完newPerson对象后,重置newPerson对象 
     this.newPerson = {name: '', age: 0, sex: 'Male'} 
    }, 
    deletePerson: function(index){ 
     // 删一个数组元素 
     this.people.splice(index,1); 
    } 
   } 
  }) 
</script> 
</html>

下载地址请点击 这里

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
jqgrid 表格数据导出实例
Nov 21 Javascript
jquery实现倒计时功能
Dec 28 Javascript
Ext JS框架程序中阻止键盘触发回退或者刷新页面的代码分享
Jun 07 Javascript
Angular的Bootstrap(引导)和Compiler(编译)机制
Jun 20 Javascript
JS全局变量和局部变量最新解析
Jun 24 Javascript
记录一篇关于redux-saga的基本使用过程
Aug 18 Javascript
关于Vue源码vm.$watch()内部原理详解
Apr 26 Javascript
使用vue脚手架(vue-cli)搭建一个项目详解
May 09 Javascript
小程序云开发教程如何使用云函数实现点赞功能
May 18 Javascript
async/await让异步操作同步执行的方法详解
Nov 01 Javascript
原生js实现文件上传、下载、封装等实例方法
Jan 05 Javascript
Vue中避免滥用this去读取data中数据
Mar 02 Vue.js
node.js与C语言 实现遍历文件夹下最大的文件,并输出路径,大小
Jan 20 #Javascript
微信小程序通过api接口将json数据展现到小程序示例
Jan 20 #Javascript
BootStrap栅格系统、表单样式与按钮样式源码解析
Jan 20 #Javascript
Vue开发过程中遇到的疑惑知识点总结
Jan 20 #Javascript
JavaScript简单验证表单空值及邮箱格式的方法
Jan 20 #Javascript
JavaScript基于Dom操作实现查找、修改HTML元素的内容及属性的方法
Jan 20 #Javascript
BootStrap CSS全局样式和表格样式源码解析
Jan 20 #Javascript
You might like
discuz加密解密函数使用方法和中文注释
2014/01/21 PHP
php中fgetcsv()函数用法实例
2014/11/28 PHP
PHP中应该避免使用同名变量(拆分临时变量)
2015/04/03 PHP
php 利用array_slice函数获取随机数组或前几条数据
2015/09/30 PHP
PHP 扩展Memcached命令用法实例总结
2020/06/04 PHP
JQuery.Ajax之错误调试帮助信息介绍
2013/07/04 Javascript
JavaScript splice()方法详解
2020/09/22 Javascript
js获取某元素的class里面的css属性值代码
2014/01/16 Javascript
JavaScript替换当前页面的方法
2015/04/03 Javascript
基于jQuery实现点击列表加载更多效果
2016/05/31 Javascript
基于jQuery实现左侧菜单栏可折叠功能
2016/12/27 Javascript
Vue2递归组件实现树形菜单
2017/04/10 Javascript
Swiper实现轮播图效果
2017/07/03 Javascript
JavaScript实现正则去除a标签并保留内容的方法【测试可用】
2018/07/18 Javascript
利用Angular2的Observables实现交互控制的方法
2018/12/27 Javascript
微信小程序 scroll-view 水平滚动实现过程解析
2019/10/12 Javascript
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
浅析JavaScript 函数柯里化
2020/09/08 Javascript
Node.js文本文件BOM头的去除方法
2020/11/22 Javascript
python版学生管理系统
2018/01/10 Python
python实现人民币大写转换
2018/06/20 Python
python使用turtle绘制分形树
2018/06/22 Python
python树莓派红外反射传感器
2019/01/21 Python
打包python 加icon 去掉cmd黑窗口方法
2019/06/24 Python
Form表单及django的form表单的补充
2019/07/25 Python
浅谈Python2之汉字编码为unicode的问题(即类似\xc3\xa4)
2019/08/12 Python
Django框架HttpRequest对象用法实例分析
2019/11/01 Python
解决pyecharts运行后产生的html文件用浏览器打开空白
2020/03/11 Python
使用Python项目生成所有依赖包的清单方式
2020/07/13 Python
OpenCV利用python来实现图像的直方图均衡化
2020/10/21 Python
10个很棒的 CSS3 开发工具 推荐
2011/05/16 HTML / CSS
Doyoueven官网:澳大利亚健身服饰和配饰品牌
2019/03/24 全球购物
英国DIY汽车维修配件网站:DIY Car Service Parts
2019/08/30 全球购物
教师学习群众路线心得体会
2014/11/04 职场文书
关于艺术节的开幕致辞
2016/03/04 职场文书
2019送给家人们的中秋节祝福语
2019/08/15 职场文书