使用Vue做一个简单的todo应用的三种方式的示例代码


Posted in Javascript onOctober 20, 2018

1. 引用vue.js

<!DOCTYPE html>
<html>
<head>
<script src="http://vuejs.org/js/vue.js"></script>
 <meta charset="utf-8">
 <title>JS Bin</title>
</head>
<body>
 <div id="root">
  <input type="text" v-model="inputValue">
  <button @click="handlerAdd">提交</button>
  <ul>
   <li 
     v-for="(item,index) of lists" 
     :key="index" 
     @click="handlerDel(index)"
    >
    {{item}}
   </li>
  </ul>
 </div>
 
 <script>
  new Vue({
   el: '#root',
   data: {
    inputValue: '',
    lists: []
   },
   methods: {
    handlerAdd: function() {
     this.lists.push(this.inputValue);
     this.inputValue = '';
    },
    handlerDel: function(index) {
     this.lists.splice(index, 1);
    }
   }
  });
 </script>
</body>
</html>

2. 全局组件注册

<!DOCTYPE html>
<html>
<head>
<script src="http://vuejs.org/js/vue.js"></script>
 <meta charset="utf-8">
 <title>JS Bin</title>
</head>
<body>
 <div id="root">
  <input type="text" v-model="inputValue">
  <button @click="handlerAdd">提交</button>
  <ul>
   <todo-item
    v-for="(item,index) of lists"
    :content = "item"
    :index = "index"
    :key = "index"
    @delete="handlerDel"
   >
   </todo-item>
  </ul>
 </div>
 
 <script>
  Vue.component('todoItem', {
   props: {
    content: String,
    index: Number
   },
   template: '<li @click="handlerClick">{{content}}</li>',
   methods: {
    handlerClick: function(){
     this.$emit('delete', this.index);
    }
   }

  });

  new Vue({
   el: '#root',
   data: {
    inputValue: '' ,
    lists: []
   },
   methods: {
    handlerAdd: function() {
     this.lists.push(this.inputValue);
     this.inputValue = '';
    },
    handlerDel: function(index) {
     this.lists.splice(index,1);
    }
   }
  });
 </script>
</body>
</html>

3. vue-cli脚手架

// Todo.Vue

<template>
 <div>
  <input type="text" v-model="inputValue">
  <button @click="handlerAdd">提交</button>
  <ul>
   <todo-item
    v-for="(item,index) of lists"
    :key="index"
    :content="item"
    :index="index"
    @delete="handlerDel"
   ></todo-item>
  </ul>
 </div>
</template>

<script>
import TodoItem from './components/todoItem'

export default {
 data () {
  return {
   inputValue: '',
   lists: []
  }
 },
 methods: {
  handlerAdd () {
   this.lists.push(this.inputValue)
   this.inputValue = ''
  },
  handlerDel (index) {
   this.lists.splice(index, 1)
  }
 },
 components: {
  'todo-item': TodoItem
 }
}
</script>

<style>

</style>
// TodoItem.vue

<template>
 <li @click="handlerClick" class="item">{{content}}</li>
</template>

<script>
export default {
 props: ['content', 'index'],
 methods: {
  handlerClick () {
   this.$emit('delete', this.index)
  }
 }
}
</script>

<style scoped>
 ul,li {
  list-style: none;
 }
 .item {
  color: blueviolet;
 }
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript解析json实例详解
Nov 05 Javascript
jQuery简单实现网页选项卡特效
Nov 24 Javascript
整理Javascript流程控制语句学习笔记
Nov 29 Javascript
利用jQuery实现CheckBox全选/全不选/反选的简单代码
May 31 Javascript
微信小程序-详解数据缓存
Nov 24 Javascript
用jQuery实现可输入多选下拉组合框实例代码
Jan 18 Javascript
JS异步文件上传(兼容IE8+)
Apr 02 Javascript
js实现鼠标移动到图片产生遮罩效果
Oct 21 Javascript
js 毫秒转天时分秒的实例
Nov 17 Javascript
详解vue几种主动刷新的方法总结
Feb 19 Javascript
js实现贪吃蛇小游戏
Oct 29 Javascript
vant中的toast轻提示实现代码
Nov 04 Javascript
Iview Table组件中各种组件扩展的使用
Oct 20 #Javascript
详解webpack打包第三方类库的正确姿势
Oct 20 #Javascript
详解ES6 Promise对象then方法链式调用
Oct 20 #Javascript
Intellij IDEA搭建vue-cli项目的方法步骤
Oct 20 #Javascript
分享5个小技巧让你写出更好的 JavaScript 条件语句
Oct 20 #Javascript
angular4 获取wifi列表中文显示乱码问题的解决
Oct 20 #Javascript
vue 项目地址去掉 #的方法
Oct 20 #Javascript
You might like
ueditor 1.2.6 使用方法说明
2013/07/24 PHP
php顺序查找和二分查找示例
2014/03/27 PHP
destoon调用discuz论坛中带图片帖子的实现方法
2014/08/21 PHP
全面解析PHP验证码的实现原理 附php验证码小案例
2016/08/17 PHP
PDO的安全处理与事物处理方法
2016/10/31 PHP
PHP实现微信支付(jsapi支付)流程步骤详解
2018/03/15 PHP
tp5(thinkPHP5)框架实现多数据库查询的方法
2019/01/10 PHP
PHP7导出Excel报ERR_EMPTY_RESPONSE解决方法
2019/04/16 PHP
PHP字符串与数组处理函数用法小结
2020/01/07 PHP
PHP常用字符串输出方法分析(echo,print,printf及sprintf)
2021/03/09 PHP
javascript Object与Function使用
2010/01/11 Javascript
实现变速回到顶部的JavaScript代码
2011/05/09 Javascript
Javascript算符的优先级介绍
2013/03/20 Javascript
jQuery 网易相册鼠标移动显示隐藏效果实现代码
2013/03/31 Javascript
表格奇偶行设置不同颜色的核心JS代码
2013/12/24 Javascript
javascript获取重复次数最多的字符
2015/07/08 Javascript
JS实现的网页背景闪电闪烁效果代码
2015/10/17 Javascript
jQuery+json实现的简易Ajax调用实例
2015/12/14 Javascript
js中class的点击事件没有效果的解决方法
2016/10/13 Javascript
JS 实现Base64编码与解码实例详解
2016/11/07 Javascript
JavaScript轻松创建级联函数的方法示例
2017/02/10 Javascript
ES6实现的遍历目录函数示例
2017/04/07 Javascript
微信小程序tabBar 返回tabBar不刷新页面
2019/07/25 Javascript
Python使用PIL模块生成随机验证码
2017/11/21 Python
python如何重载模块实例解析
2018/01/25 Python
Python中Numpy包的安装与使用方法简明教程
2018/07/03 Python
Python 图像对比度增强的几种方法(小结)
2019/09/25 Python
Python实现网络聊天室的示例代码(支持多人聊天与私聊)
2021/01/27 Python
全球最大的游戏市场:G2A
2018/07/05 全球购物
介绍一下Linux内核的排队自旋锁
2014/08/27 面试题
2014报到证办理个人委托书
2014/10/08 职场文书
清明节寄语2015
2015/03/23 职场文书
2015年度校学生会工作总结报告
2015/05/23 职场文书
2016关于学习党章的心得体会
2016/01/15 职场文书
python3.7.2 tkinter entry框限定输入数字的操作
2021/05/22 Python
nginx实现多geoserver服务的负载均衡
2022/05/15 Servers