看完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
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的功能示例代码
# 绑定
# 未完成
# 文本框
# 是个
# 不存在
# 看完
# 会对
# 找个
# 三种
# 可以直接
# 自定义
# 双击
# 用过
# 或者说
# 要你
# 写完
# 一键
# 拖到
# 值为
# 大家多多
相关文章:
,想在网上投简历,哪几个网站比较好?
建站之星安装失败:服务器环境不兼容?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
C++如何编写函数模板?(泛型编程入门)
建站主机如何选?高性价比方案全解析
建站主机与虚拟主机有何区别?如何选择最优方案?
广州建站公司哪家好?十大优质服务商推荐
利用JavaScript实现拖拽改变元素大小
Bpmn 2.0的XML文件怎么画流程图
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何将凡科建站内容保存为本地文件?
如何用AWS免费套餐快速搭建高效网站?
如何在万网ECS上快速搭建专属网站?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
如何用免费手机建站系统零基础打造专业网站?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
如何通过FTP服务器快速搭建网站?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何通过商城自助建站源码实现零基础高效建站?
创业网站制作流程,创业网站可靠吗?
如何零成本快速生成个人自助网站?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
教学论文网站制作软件有哪些,写论文用什么软件
?
相册网站制作软件,图片上的网址怎么复制?
三星网站视频制作教程下载,三星w23网页如何全屏?
C++中引用和指针有什么区别?(代码说明)
电脑免费海报制作网站推荐,招聘海报哪个网站多?
Android自定义listview布局实现上拉加载下拉刷新功能
网站制作服务平台,有什么网站可以发布本地服务信息?
山东云建站价格为何差异显著?
如何通过FTP空间快速搭建安全高效网站?
香港服务器如何优化才能显著提升网站加载速度?
建站之星3.0如何解决常见操作问题?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
制作企业网站建设方案,怎样建设一个公司网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
名字制作网站免费,所有小说网站的名字?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
定制建站流程解析:需求评估与SEO优化功能开发指南
郑州企业网站制作公司,郑州招聘网站有哪些?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何快速搭建自助建站会员专属系统?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
如何快速查询网址的建站时间与历史轨迹?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
*请认真填写需求信息,我们会在24小时内与您取得联系。