全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

看完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

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


# vue  # todolist  # 案例  # vuejs  # Vue中父子组件通讯之todolist组件功能开发  # Vue从TodoList中学父子组件通信  # 详解Vue的computed(计算属性)使用实例之TodoList  # vue实现ToDoList简单实例  # 利用vue写todolist单页应用  # vue组件编写之todolist组件实例详解  # 使用Vue完成一个简单的todolist的方法  # Vue.js实现简单ToDoList 前期准备(一)  # vue实现留言板todolist功能  # 使用Vue父子组件通信实现todolist的功能示例代码  # 绑定  # 未完成  # 文本框  # 是个  # 不存在  # 看完  # 会对  # 找个  # 三种  # 可以直接  # 自定义  # 双击  # 用过  # 或者说  # 要你  # 写完  # 一键  # 拖到  # 值为  # 大家多多 


相关文章: 建站主机如何选?性能与价格怎样平衡?  如何高效利用200m空间完成建站?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何用wdcp快速搭建高效网站?  怀化网站制作公司,怀化新生儿上户网上办理流程?  建站之星安装模板失败:服务器环境不兼容?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  北京的网站制作公司有哪些,哪个视频网站最好?  建站主机CVM配置优化、SEO策略与性能提升指南  广平建站公司哪家专业可靠?如何选择?  建站之星上传入口如何快速找到?  如何在云主机上快速搭建网站?  建站上传速度慢?如何优化加速网站加载效率?  三星网站视频制作教程下载,三星w23网页如何全屏?  制作表格网站有哪些,线上表格怎么弄?  建站之星官网登录失败?如何快速解决?  如何零成本快速生成个人自助网站?  建站主机无法访问?如何排查域名与服务器问题  建站之星伪静态规则如何设置?  微信推文制作网站有哪些,怎么做微信推文,急?  临沂网站制作公司有哪些,临沂第四中学官网?  建站之星安装失败:服务器环境不兼容?  兔展官网 在线制作,怎样制作微信请帖?  php json中文编码为null的解决办法  个人摄影网站制作流程,摄影爱好者都去什么网站?  建站之星导航如何优化提升用户体验?  简单实现Android文件上传  山东网站制作公司有哪些,山东大源集团官网?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  建站为何优先选择香港服务器?  如何撰写建站申请书?关键要点有哪些?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  行程制作网站有哪些,第三方机票电子行程单怎么开?  建站主机数据库如何配置才能提升网站性能?  如何在IIS中新建站点并解决端口绑定冲突?  网站制作壁纸教程视频,电脑壁纸网站?  定制建站策划方案_专业建站与网站建设方案一站式指南  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  建站之星与建站宝盒如何选择最佳方案?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站主机与服务器功能差异如何区分?  平台云上自主建站:模板化设计与智能工具打造高效网站  名字制作网站免费,所有小说网站的名字?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  装修招标网站设计制作流程,装修招标流程?  网站制作公司,橙子建站是合法的吗?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  为什么Go需要go mod文件_Go go mod文件作用说明 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。