vue2的todolist入门小项目的详细解析


Posted in Javascript onMay 11, 2017

看完vue2的官方文档后,找个入门项目巩固下知识点,简单的todolsit是个不错的选择。

项目用到了vue.js vue.cli webpack ES6 node环境,完成项目后会对这些技术栈有了些了解。

准备开发环境

$ npm install -g vue-cli
$ vue init ,比如 vue init webpack todolist
$ cd todolist
$ npm install
$ npm run dev
  1. 安装谷歌插件vue.js devtools
  2. 下载vue.js的webpack模板
  3. 下载todomvc的模板 (提供html和css)(也可以直接$ git clone https://github.com/tastejs/todomvc-app-template.git 来下载)
  4. 把todomvc的index.html拖到todolist文件夹去覆盖里面的index.html
  5. 打开todomvc的json文件,会看到 “todomvc-app-css”: “^2.0.0”,就是要你 npm install todomvc-app-css -S 从而下载该css
  6. 删点todolsit index.html的默认css,js引用,src文件夹下的main.js引入模板css(import‘todomvc-app-css/index.css')
  7. 引入vue(import Vue form ‘vue')
  8. 等写完代码后 $npm run build 一键打包构建,会看到dist文件夹

main.js的代码

//后面的为注释讲解, ~表示串联index.html的对应内容

import 'todomvc-app-css/index.css'
import Vue from 'vue'
//添加localStorage
var STORAGE_KEY = 'todos-vuejs-2.0'
var todoStorage = {
 fetch: function () {
  var todos = JSON.parse(localStorage.getItem(STORAGE_KEY) || '[]')
  todos.forEach(function (todo, index) {
   todo.id = index
  })
  todoStorage.uid = todos.length
  return todos
 },
 save: function (todos) {
  localStorage.setItem(STORAGE_KEY, JSON.stringify(todos))
 }
}
//用过滤器筛选出三种状态
var filters = {
 all(todos) {
  return todos
 },
 active(todos) {
  return todos.filter((todo) => {
   return !todo.completed
  })
 },
 completed(todos) {
  return todos.filter((todo) => {
   return todo.completed
  })
 },
}
let app = new Vue({
 el: '.todoapp',  // ~ <section class="todoapp">
 data: {
  msg: 'hello world',
  title: '待做清单',  // 渲染标题 ~ {{title}}
  newTodo: '',
   todos: todoStorage.fetch(), // ~ v-show="todos.length" ; ~ {{todos.length>1?'items':'item'}} 渲染 li ~ v-for="(todo,index) in filteredTodos" 
  editedTodo: '',  // 空的编辑对象
  hashName: 'all'  
 },
 
 watch: {
  todos: {
   handler: function (todos) {
    todoStorage.save(todos)
   },
   deep: true
  }
 },
 
 computed: {
  remain() {
   return filters.active(this.todos).length  //未完成事项的数量 ~ {{remain}}
  }, 
  isAll: {   // ~ v-model="isAll"
   get() {
    return this.remain === 0
   },
   set(value) {
    this.todos.forEach((todo) => {
     todo.completed = value
    })
   }
  },
  filteredTodos() {  //用hashName过滤出当前页面的todos ~ v-for="(todo,index) in filteredTodos" 
   return filters[this.hashName](this.todos)
  }
 },
 methods: {
  addTodo(e) { //输入值为空时,不添加(trim去除前后空格) ~ v-model.trim="newTodo" 
   if (!this.newTodo) {
    return
   }
   this.todos.push({
    id: todoStorage.uid++,
    content: this.newTodo,
    completed: false //结合v-model 根据completed状态绑定样式 ~:class="{completed:todo.completed; ~ v-model="todo.completed"
   })
   this.newTodo = ''
  },
  removeTodo(index) {  //绑定x样式,点击删除该todo ~ @click="removeTodo(index)"
   this.todos.splice(index, 1)
  },
  editTodo(todo) {     //编辑 ~ @dblclick="editTodo(todo)"
   this.editCache = todo.content //储存编辑前的内容
   this.editedTodo = todo // 点击编辑里面的内容而不是只是空文本框~ editing:todo==editedTodo}"
  },
  doneEdit(todo, index) { //失去焦点后 ~ @blur="doneEdit(todo)";@keyup.enter="doneEdit(todo)"
   this.editedTodo = null //不存在编辑了或者说编辑已完成
   if (!todo.content) { //如果编辑后没有内容了,删除该todo
    this.removeTodo(index)
   }
  },
  cancelEdit(todo) {  //按esc键取消此次编辑操作 ~ @keyup.esc="cancelEdit(todo)">
   this.editedTodo = null   
   todo.content = this.editCache //当esc取消编辑时,还原编辑前的内容
  },
  clear() { //点击清除已完成的功能 ~ @click="clear"
   this.todos = filters.active(this.todos) //获取并渲染未完成的事项 ~ 
  }
 },
 directives: {  //自定义属性 ~ v-focus="todo == editedTodo"
  focus(el, value) { //文本框双击获取焦点
   if (value) {
    el.focus()
   }
  }
 }
})
//hash(url地址中#以及之后的字符)
function hashChange() { 
// ~ :class="{selected:hashName=='all'}";:class="{selected:hashName=='active'}";:class="{selected:hashName=='completed'}"
 let hashName = location.hash.replace(/#\/?/, '') //正则表达式去除#/?,获取如all,active,completed
 if (filters[hashName]) {  //如果过滤状态的hashName存在
  app.hashName = hashName //给整个app变量里的hashName赋上那个值
 } else {
  location.hash = ''  //取消
  app.hashName = 'all' //否则就赋值‘all',回到全部事项的页面
 }
}
window.addEventListener('hashchange', hashChange) //全局监听hash

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

Javascript 相关文章推荐
js判断输入是否为正整数、浮点数等数字的函数代码
Nov 17 Javascript
浅析用prototype定义自己的方法
Nov 14 Javascript
JavaScript中0和&quot;&quot;比较引发的问题
May 26 Javascript
jQuery实现的网页换肤效果示例
Sep 20 Javascript
JavaScript实现的微信二维码图片生成器的示例
Oct 26 Javascript
jquery 实现复选框的全选操作实例代码
Jan 24 Javascript
浅谈express 中间件机制及实现原理
Aug 31 Javascript
Vue.js2.0中的变化小结
Oct 24 Javascript
vue.js使用v-if实现显示与隐藏功能示例
Jul 06 Javascript
fastadmin中调用js的方法
May 14 Javascript
详解利用eventemitter2实现Vue组件通信
Nov 04 Javascript
ajax请求前端跨域问题原因及解决方案
Oct 16 Javascript
ionic实现底部分享功能
May 11 #Javascript
学习使用Bootstrap栅格系统
May 11 #Javascript
jQuery实现的简单在线计算器功能
May 11 #jQuery
学习使用Bootstrap页面排版样式
May 11 #Javascript
Angularjs 与 bower安装和使用详解
May 11 #Javascript
学习使用Bootstrap输入框、导航、分页等常用组件
May 11 #Javascript
es6学习笔记之Async函数基本教程
May 11 #Javascript
You might like
PHP计数器的实现代码
2013/06/08 PHP
PHP+MYSQL实现读写分离简单实战
2017/03/13 PHP
PHP静态方法和静态属性及常量属性的区别与介绍
2019/03/22 PHP
DHTML Slide Show script图片轮换
2008/03/03 Javascript
javaScript 关闭浏览器 (不弹出提示框)
2010/01/31 Javascript
JS俄罗斯方块,包含完整的设计理念
2010/12/11 Javascript
最佳6款用于移动网站开发的jQuery 图片滑块插件小结
2012/07/20 Javascript
常用的JS验证和函数汇总
2014/12/23 Javascript
Javascript连接Access数据库完整实例
2015/08/03 Javascript
JQuery zClip插件实现复制页面内容到剪贴板
2015/11/02 Javascript
jQuery限制图片大小的方法
2016/05/25 Javascript
老生常谈的跨域处理
2017/01/11 Javascript
NodeJS仿WebApi路由示例
2017/02/28 NodeJs
EasyUI中的dataGrid的行内编辑
2017/06/22 Javascript
Vue仿微信app页面跳转动画效果
2019/08/21 Javascript
vue限制输入框只能输入8位整数和2位小数的代码
2019/11/06 Javascript
JS桶排序的简单理解与实现方法示例
2019/11/25 Javascript
vue各种事件监听实例(小结)
2020/06/24 Javascript
js实现电灯开关效果
2021/01/19 Javascript
python基础教程之简单入门说明(变量和控制语言使用方法)
2014/03/25 Python
详细介绍Python中的偏函数
2015/04/27 Python
TF-IDF算法解析与Python实现方法详解
2017/11/16 Python
python numpy 常用随机数的产生方法的实现
2019/08/21 Python
PyTorch中Tensor的数据统计示例
2020/02/17 Python
jupyter notebook插入本地图片的实现
2020/04/13 Python
python实现模拟器爬取抖音评论数据的示例代码
2021/01/06 Python
亚洲最大的眼镜批发商和零售商之一:Glasseslit
2018/10/08 全球购物
进程的查看和调度分别使用什么命令
2013/12/14 面试题
公司综合部的成员自我评价分享
2013/11/05 职场文书
基层党建工作宣传标语
2014/06/24 职场文书
大学生党员自我批评思想汇报
2014/10/10 职场文书
2015年化验室工作总结
2015/04/23 职场文书
2015年环卫工作总结
2015/04/28 职场文书
2016年9月份红领巾广播稿
2015/12/21 职场文书
导游词之湖州-太湖
2019/10/11 职场文书
springboot读取resources下文件的方式详解
2022/06/21 Java/Android