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 相关文章推荐
js触发select onchange事件的小技巧
Aug 05 Javascript
jQuery中的each()详细介绍(推荐)
May 25 Javascript
Bootstrap源码解读标签、徽章、缩略图和警示框(8)
Dec 26 Javascript
深入理解react-router@4.0 使用和源码解析
May 23 Javascript
20行JS代码实现网页刮刮乐效果
Jun 23 Javascript
浅谈Vue-cli 命令行工具分析
Nov 22 Javascript
vue通过style或者class改变样式的实例代码
Oct 30 Javascript
浅谈React碰到v-if
Nov 04 Javascript
为vue项目自动设置请求状态的配置方法
Jun 09 Javascript
vue实现购物车小案例
Sep 27 Javascript
解决vue做详情页跳转的时候使用created方法 数据不会更新问题
Jul 24 Javascript
微信小程序实现日历签到
Sep 21 Javascript
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
DC动画电影《黑暗正义联盟》曝预告 5月5日上线数字平台
2020/04/09 欧美动漫
php排序算法(冒泡排序,快速排序)
2012/10/09 PHP
php中的curl使用入门教程和常见用法实例
2014/04/10 PHP
基于JQuery+PHP编写砸金蛋中奖程序
2015/09/08 PHP
使用php实现网站验证码功能【推荐】
2017/02/09 PHP
PHP单元测试配置与使用方法详解
2019/12/27 PHP
php中array_fill函数的实例用法
2021/03/02 PHP
JS解密入门之凭直觉解
2008/06/25 Javascript
javaScript Array(数组)相关方法简述
2009/07/25 Javascript
NodeJS url验证(url-valid)的使用方法
2013/11/18 NodeJs
JavaScript设计模式之外观模式实例
2014/10/10 Javascript
jQuery实现流动虚线框的方法
2015/01/29 Javascript
javascript验证邮件地址和MX记录的方法
2015/06/16 Javascript
微信小程序  网络请求API详解
2016/10/25 Javascript
canvas 绘制圆形时钟
2017/02/22 Javascript
js+html5实现手机九宫格密码解锁功能
2018/07/30 Javascript
使用electron制作满屏心特效的示例代码
2018/11/27 Javascript
小程序转发探索示例
2019/02/19 Javascript
d3.js 地铁轨道交通项目实战
2019/11/27 Javascript
Jquery使用each函数实现遍历及数组处理
2020/07/14 jQuery
浅谈es6中的元编程
2020/12/01 Javascript
[01:05:40]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第三场
2014/05/24 DOTA
Python中除法使用的注意事项
2014/08/21 Python
Python爬虫包 BeautifulSoup  递归抓取实例详解
2017/01/28 Python
Django admin禁用编辑链接和添加删除操作详解
2019/11/15 Python
Python实现投影法分割图像示例(一)
2020/01/17 Python
Python实现桌面翻译工具【新手必学】
2020/02/12 Python
基于plt.title无法显示中文的快速解决
2020/05/16 Python
纯CSS3实现漂亮的input输入框动画样式库(Text input love)
2018/12/29 HTML / CSS
浅谈Html5多线程开发之WebWorkers
2018/05/02 HTML / CSS
基于HTML5+tracking.js实现刷脸支付功能
2020/04/16 HTML / CSS
荷兰优雅女装网上商店:Heine
2016/11/14 全球购物
校园摄影活动策划方案
2014/02/05 职场文书
公共场所禁烟标语
2014/06/25 职场文书
学校中秋节活动总结
2015/03/23 职场文书
实用干货:敬酒词大全,帮你应付各种场合
2019/11/21 职场文书