使用Vuex实现一个笔记应用的方法
最近开始着手学习 Vue,先大略的过了一遍官方文档,跟着敲过一部分官方文档中的 DEMO,然而还是不甚了了。在网上找到了一个入门的笔记应用,即便是入门级的应用,在学习途中依旧困难重重。特将学习作此笔记,方便今后回看,也希望能够帮到刚开始学习 Vue 的女同学 附原作者 Github 链接:https://github.com/lichenbuliren/vuex-notes-app2 预期目标笔记具备如下基本功能 1.新增 2.删除 3.收藏 4.在全部笔记和收藏笔记间切换 5.在当前列表中进行搜索
准备工作1.新建项目 选个文件夹存放项目,这里我用的是 Git Bush 执行语句($ 符号是 Git Bush 中自带的),你也可以使用命令行,一样的
2.查看模块(爱看不看)查看一下全局安装的模块 npm list --depth=0 -global
3.创建项目在命令行输入 vue init webpack vuex-note 并做好设置,创建一个项目
4.简单解释一下各个配置都是干嘛的
5.安装完后会有提示,我们接着按照提示走先是 cd vuex-note 进入刚刚创建的 vue 项目文件夹
再通过 npm run dev 跑起项目
6.访问页面此时通过浏览器访问 localhost:8080 就可以打开一个新的 vue 页面
7.项目结构截止目前的项目结构如图
由于是初学,为了先搞个东西出来,所以暂时先不管一些乱七八糟的配置,只挑跟这次相关的说(其实多了我也没学到...) 8.查看 Vuex既然是使用 Vuex 来实现笔记应用,我们就应该先查看一下构建的项目是否包含 Vuex 模块。 node_modules 文件夹包含了现有的模块,然而里面并没有我们想要的 Vuex,不信自己去看 package.json 文件描述了项目包含的文件,项目如何运行等信息
9.安装 Vuex在命令行中输入 npm install vuex --save:--save 就是将安装信息写入 package.json
至此,所有前期工作已经准备完成,遗漏的部分将在实现过程中逐一解释 搞起零、思路整个应用可拆分为三个组件
一、index.html
vuex-note
这个没什么说的,注意 div 的 ID 就行 二、main.jsVue.config.productionTip = false
new Vue({ 1.在 import 时什么时候需要 ' ./ '?从项目模块中导出,引入时不需要 ./,而从自己写的组件中引入时需要 ./ 2.什么时候需要 import {aaa} from abc 这种加大括号的引入?什么时候不需要?当 abc 中被导出的部分是 export aaa 时 当 import 的是被 export default 导出的部分时不加 {},并且可以起个别名 3.项目结构中并没有 store 文件,只有 store 文件夹,那 import store from './store' 是什么意思?不知道,求指教 4. new Vue 中单独的 store 是什么意思?ES6 的一种简写方式,缩写之前是 store:store,这句话的意思是为全局注入 Vuex,这样在各个组件中都可以通过 this.$store 去调用状态库,如果不在全局注入,则需要在每个组件中单独引入,多了会很麻烦 三、store 下的 index.jsVue.use(Vuex)
const defaultNote = { // 可以理解为一个状态的仓库 export default new Vuex.Store({ 1. Vue.use(Vuex) 是什么意思?使用 Vuex,今后用 Vue-router 时也得来这么一出,只是得写在 route 文件夹下的 index.js 文件中 2. +new Date() 是什么意思?获取时间戳的另一种写法,等同于 new Date().getTime() 3.state,getters,mutations,actions 之间的关系?state:如上所言状态仓库 getters:state 的修饰,比如 state 中有 str:"abc" 这么个属性,而在很多组件中需要进行 str + "def" 的操作,如果在每个组件都进行 str + "def" 的操作未免太麻烦,于是可以在 getters 中增加: 今后在组件中使用 strAdd 就可以了
四、tool.vue1.data 中的 search 是干嘛的?可不可以写在 computed 中? 用来与搜索框进行关联。可以写在 computed 中,但 computed 中的属性默认都是 getter ,就是只能获取值,如果想修改,需要设置 setter ,详见官方文档 六、edit.vue |