看完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
- 安装谷歌插件vue.js devtools
- 下载vue.js的webpack模板
- 下载todomvc的模板 (提供html和css)(也可以直接$ git clone https://github.com/tastejs/todomvc-app-template.git 来下载)
- 把todomvc的index.html拖到todolist文件夹去覆盖里面的index.html
- 打开todomvc的json文件,会看到 “todomvc-app-css”: “^2.0.0”,就是要你 npm install todomvc-app-css -S 从而下载该css
- 删点todolsit index.html的默认css,js引用,src文件夹下的main.js引入模板css(import‘todomvc-app-css/index.css')
- 引入vue(import Vue form ‘vue')
- 等写完代码后 $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"(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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“vue2的todolist入门小项目的详细解析”评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年10月28日
2025年10月28日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]