本次分享是一系列分享的重点,所以准备分 2 - 3 次完成最后 vue 到 jquery 的分享。代码大家可以 todoMVC 下载一个 jquery 版本,我是以此为例进行代码转换的。
data:image/s3,"s3://crabby-images/5eeb3/5eeb35e502a2e3ad38de2f107e62fd3793f83a2a" alt=""
首先我们引入 vue.js, 有关 vue 安装很简单,大家可以下载 vue.js 或者通过 npm install 来安装,这里我采用后者方式安装 vue.js。
data:image/s3,"s3://crabby-images/e4f21/e4f2107f8188d5d558f40ca85ca46f49ebc2b34d" alt=""
开发的 IDE 我用的 visual studio code , 自从 visual studio code 出现我看到微软从封闭走向开发,而且微软产品真心不错。我们再次运行程序。
data:image/s3,"s3://crabby-images/a08b9/a08b9da4bf9eddae006af226681451f27952fc24" alt=""
我们将jqeury 版的 app.js 复杂一份改名为 j-app.js 留作备用。
data:image/s3,"s3://crabby-images/bf2a9/bf2a9b4f95ba3d7afe2991714fa3014a15306c2e" alt=""
然后我们需要确定我们的应用范围,我们用 id 作为标识来确定应用的范围。然后我们就搭建我们的 vue 的应用。
data:image/s3,"s3://crabby-images/5f0aa/5f0aaab78d107aa1c0a3f045e6fc9556f264f617" alt=""
data:image/s3,"s3://crabby-images/e22c1/e22c1e6776f5617ca23e0e5ddfbb9e3f1de7fd3c" alt=""
然后我们测试一下,添加一个 {{todos}} 来测试我们的代码。
data:image/s3,"s3://crabby-images/c2d6c/c2d6c63d6fb6c8865bdd9165829d2b56c1745cd8" alt=""
data:image/s3,"s3://crabby-images/f2699/f26993c4049d3d1b092686a09558289e77baf366" alt=""
好我们既然将 jQuery 版本转为 vue 。我们就不需要一切都是重头来做。我们返回到备份文件,对有用的代码保留调整,我们先删除这部分代码。
data:image/s3,"s3://crabby-images/91f3f/91f3f17d12df95997fd6d9f104394ce5953afd3d" alt=""
然后将可以复用的 util 中的内容保留复制到 methods。
data:image/s3,"s3://crabby-images/aeff5/aeff535c648e3cd6cb78cec88ba405638379b09f" alt=""
data:image/s3,"s3://crabby-images/c5d57/c5d570d05fe341ba4f46b0a28ba339f7a093c61b" alt=""
这样我们将本地保存的数据显示出来,可以调用 store 中的方法来显示数据。
data:image/s3,"s3://crabby-images/f7d99/f7d99bf6e6d058e69a7c5c984ea1176c8b4cccf3" alt=""
在数据结构我们除了要显示数据列表,还有一个新的数据。表示我们新创建的数据。
data:image/s3,"s3://crabby-images/66775/66775923cb739b022341cfbc7aea5646c033baa7" alt=""
然后我们就需要将 newTodo 绑定到 input 输入框上。
data:image/s3,"s3://crabby-images/bfd31/bfd31f8eb76a32ec880ad44da9f44e6b77052145" alt=""
然后我们再次回到备份代码上,删除去掉这些代码,然后我们这里保留 director.js 的作为我们代码路由。
data:image/s3,"s3://crabby-images/fdb03/fdb03f2a30bf7b5b0bcf30a7c6225a3ca99d81a4" alt=""
我们将 Router 复制到 created 这个生命周期阶段。
data:image/s3,"s3://crabby-images/593e9/593e9adeaae0e7ccda21959eaedad5d0bee6162e" alt=""
然后我们将函数修改我箭头式函数,也就是 lamba 这样我们就无需绑定 this,这是=>好处,大家千万不要简单用箭头式函数好处仅仅是好看,其实好处多多。然后我们可创建一个 filter。
data:image/s3,"s3://crabby-images/427bd/427bd057eeb1503610af43cce6eecd68d4748ccd" alt=""
然后我们处理的 create 任务的方法,
data:image/s3,"s3://crabby-images/ca396/ca3964b29bb4c9f5772d4819c0df69c8024fd597" alt=""
然后将 create 修改为 addTodo 名称,
data:image/s3,"s3://crabby-images/01a4a/01a4abc52024aae400894965b0b2578a9a58982d" alt=""
我们进行修改,然后将 newTodo 绑定 input 的 keyup 事件上。
data:image/s3,"s3://crabby-images/280d6/280d6ff1893645a98e547c894af4beb2c08b4286" alt=""
data:image/s3,"s3://crabby-images/1a6de/1a6dee74db763a2e55532a0b40b2c034ac14245e" alt=""
data:image/s3,"s3://crabby-images/18c31/18c31819dbb11406e53b4aab953a9706383f5422" alt=""
然后我们将 display 的样式删除,我们不需要。
data:image/s3,"s3://crabby-images/eb024/eb024472ba35ee3850421b5fa3320f780a492e07" alt=""
在 vue 中我们就不再需要模板来渲染界面,我们将模板部分的 html 代码移动到 ul 标签下,
data:image/s3,"s3://crabby-images/b32ec/b32ecf0f4cefce1e6a908bde85985be7bbd438d2" alt=""
data:image/s3,"s3://crabby-images/05164/0516486f3380b5ec2d9008c212121a5961f103d2" alt=""
然后我们用 v-for 来实现列表的显示,然后绑定 class 为 completed 。
data:image/s3,"s3://crabby-images/f58cd/f58cd06b303700c38ec0068d834aaf8a27caecf5" alt=""
data:image/s3,"s3://crabby-images/1c531/1c53139bc1903c645518afa6854d3430b5ec5957" alt=""
网友评论