Vue是近年出的一个前端构建数据驱动的web界面的库,主要的特色是响应式的数据绑定,区别于以往的命令式用法。也就是在var a=1;的过程中,拦截’=’的过程,从而实现更新数据,web视图也自动同步更新的功能。而不需要显式的使用数据更新视图(命令式)。这种用法我最早是在VC MFC中见过的,控件绑定变量,修改变量的值,输入框也同步改变。
Vue的官方文档,网上的解析文章都很详细,不过出于学习的目的,还是了解原理后,自己实现一下记忆深刻,同时也可以学习下Js的一些知识。搞这行的,一定要多WTFC(Write The Fucking Code)。
一、思考设计
其实这里的思考是在看过几篇文章、看过一些源码后补上的,所以有的地方会有上帝视角的意思。但是这个过程是必须的,以后碰到问题就会有思考的方向。先看看我们想要实现什么功能,以及现在所具有的条件:
效果图如下:
![f3484eff41c8cf3d167dea7897a95fb4.gif](https://i-blog.csdnimg.cn/blog_migrate/a4771316706bb0a9d81f4fa02c8e1824.gif)
使用Vue框架代码如下:
<html lang="en"><head> <meta charset="UTF-8"> <title>MVVMtitle>head><body><script src="src/vue.js">script><div id="msg"> {
{b.c}}这是普通文本{
{b.c+1+message}}这是普通文本 <p>{
{message}}p> <p><input type="text" v-model="message"/>p> <p>{
{message}}p> <p><button type="button" v-on:click="clickBtn(message)">click mebutton>p>div><script> var vm = new Vue({
el:"#msg", data:{
b:{
c:1 }, message:"hello world" }, methods:{
clickBtn:function(message){
vm.message = "clicked"; } } });script>body>html>
然后我们还知道一个条件,Vue的官方文档所说的:
把一个普通对象传给 Vue 实例作为它的 data 选项,Vue.js 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter。这是 ES5 特性,不能打补丁实现,这便是为什么 Vue.js 不支持 IE8 及更低版本。
用这个特性实现这样的功能,我们需要做什么呢?
首先,