庞永胜

仿vue实现简易版mvvm双向绑定

项目地址:https://github.com/pangyongsheng/mvvm

1、 指令

  • vm-bind 单选数据绑定- 将数据显示到标签视图
  • vm-model : 双向数据绑定
  • vm-show : 是否显示
  • vm-show : 是否显示
  • vm-if/v-else : 条件判断
  • vm-click:绑定事件
  • vm-src:标签资源绑定
  • vm-attr="key:value":html标签属性绑定
  • {{x}}双花括号数据绑定
  • vm-bind="css属性:值" bind绑定css属性

2、示例dome(详细见dist/index.html)

(1)js

new viewModel({
el:'#wrap', //@绑定节点
data:{ //@数据
title:"双向绑定使用dome",
count:0,
...
},
methods:{ //@方法-事件调用(this指向data)
increment:function(a){
this.count+=parseInt(a);
},
...
},
create:function(init){ //@业务逻辑(this指向data)
var _this=this;
setTimeout(function(){
_this.count=5;
init();
},2000)

}
})

(2)html

<div id="wrap"  vm-hidden>
<h1 style="text-align: center;">双向绑定使用dome</h1>
<br>
<h3>1、vm-bind 单项绑定</h3>
<p>在标签中添加vm-bind="数据"属性,标签中内容显示绑定数据:如</p>
<p vm-bind="title"></p>
<br>

<h3>2、vm-model双向绑定</h3>
<p>在input中添加vm-model="数据"属性,实现视图与数据同步,如下:</p>
<input type="text" vm-model="text">
<span vm-bind="text"></span>
<br>

<h3>3、vm-click添加点击事件,如:</h3>
<p>在标签中添加vm-click="方法",点击元素调用方法</p>
<button vm-click="increment(1)">点我加一</button>
<span vm-bind="count"></span>
<br>

<h3>4、双花括号绑定,如:</h3>
<p>使用{{数据}}绑定数据到界面</p>
<p>{{word}}</p>
<br>

<h3>5、vm-show实现元素的显示和隐藏</h3>
<p>在元素中添加vm-show属性,根据数据的真假实现元素的显示隐藏,如:</p>
<button vm-bind="sh" vm-click="toChange"></button>
<div vm-show="isshow">xxxxxxxxxx</div>

<h3>6、vm-for实现列表循环显示</h3>
<p>在元素中添加vm-show="数据"属性,该标签会根据数据循环显示,如:</p>
<ul>
<li vm-for="li in list">
<span>{{li.name}}</span>
<span>{{li.sex}}</span>
</li>
</ul>
<br>

<h3>6、vm-src绑定元素src</h3>
<p>在元素中添加vm-src="数据"属性,该标签会根据数据循环显示,如:</p>
<img vm-src="imgSrc" alt="">
<br>

<h3>7、vm-attr绑定元素属性</h3>
<p>在元素中添加vm-attr="属性名:数据"属性,该标签会根据数据循环显示,如:</p>
<p vm-attr="id:idName">xxxxxxx</p>
<br>

<h3>8、vm-bind绑定css样式</h3>
<p>在元素中添加vm-bind="style属性:数据"属性,该标签会根据数据循环显示,如:</p>
<p vm-bind="color:col">我是红色的</p>
<br>

<!-- -->
<hr>
<p>上述指令和结合在一起使用</p>
</div>

3、 目录结构


mvvm

  • src
     vm.js--------创建VM对象,初始化数据
     compile.js---dom编译模块
     directive.js--指令模块
     convert.js---数据劫持模块
     index.html--示例dome
  • dist
     vm.js--------打包压缩后的js
     index.html--示例dome

 

posted @ 2017-12-27 18:06  庞永胜  阅读(503)  评论(0编辑  收藏  举报