<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<div id='app'>

<input style="width: 200px;height: 38px;outline: none;display: inline-block;" type='text'  v-model='text' />{{text}}

<input style="width: 200px;height: 38px;outline: none;display: inline-block;" type='text'  v-model='name' />{{name}}

<div style="width: 200px;height: 40px;background: red;" v-if='show'></div>

</div>

<script>

function Vue(options){

this.data=options.data;

var id=options.el;

var data=this.data;

this.observe(data,this)

var dom=this.tofagerment(document.getElementById(id),this);

var pardom=document.getElementById(id).appendChild(dom)

}

Vue.prototype.tofagerment=function(node,vm){

var flag=document.createDocumentFragment();

var child="";

while(child = node.firstChild){

this.compile(child,vm)

flag.append(child);

}

return flag

}

Vue.prototype.compile=function(child,vm){

var name=""

if(child.nodeType==1){

if(child.hasAttribute('v-model')){

name=child.getAttribute('v-model');

child.addEventListener('input',function(e){

var e=e||window.event;

var target=e.target||e.srcElement;

vm[name]=target.value;

})

child.value=vm[name];

child.removeAttribute('v-model')

}

}else if(child.nodeType==3){

var reg=/\{\{(.*)\}\}/;

if(reg.test(child.nodeValue)){

var regname=reg.exec(child.nodeValue)[1];

regname=regname.trim();

child.nodeValue=vm[regname]

}

new Watcher(vm,child,regname)

};

}

//订阅

Vue.prototype.observe=function(obj,vm){

Object.keys(obj).forEach(function(key){

console.log(obj[key])

vm.defineReactive(vm,key,obj[key])

})

}

// 消费

Vue.prototype.defineReactive=function(obj, key , value){

var dep=new Dep()

Object.defineProperty(obj,key,{

get:function(){

console.log('获取值');

if(Dep.target){

console.log(32423423)

dep.addSub(Dep.target)

}

return value

},

set:function(newValue){

console.log('设置值'+newValue);

if(newValue==value)return ;

value=newValue;

dep.notify()

}

})

}

//观察者模式

function Watcher(vm,node,name){

Dep.target=this

this.vm=vm;

this.node=node;

this.name=name;

this.update();

Dep.target=null

}

Watcher.prototype.get=function(){

this.value=this.vm[this.name]

}

Watcher.prototype.update=function(){

this.get()

this.node.nodeValue=this.value

}

//发布者

function Dep(){

this.subs=[];//订阅客户

}

Dep.prototype.addSub=function(sub){

this.subs.push(sub)

}

Dep.prototype.notify=function(sub){

this.subs.forEach(function(item){

item.update()

})

}

var myvue=new Vue({

el:"app",

data:{

text:'1312323123',

name:"eqwewqeqeq",

show:false,

}

})

</script>

</body>

</html>

原生js开发vue的双向数据绑定的更多相关文章

  1. Vue基础01vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令

    自学vue框架,每天记录重要的知识点,与大家分享!有不足之处,希望大家指正. 本篇将讲述:vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令 前期学习基础,使用vue. ...

  2. 原生js开发,无依赖、轻量级的现代浏览器图片懒加载插件,适合在移动端开发使用

    优势 1.原生js开发,不依赖任何框架或库 2.支持将各种宽高不一致的图片,自动剪切成默认图片的宽高 比如说你的默认图片是一张正方形的图片,则各种宽度高度不一样的图片,自动剪切成正方形. 完美解决移动 ...

  3. 面试题:你能写一个Vue的双向数据绑定吗?

    在目前的前端面试中,vue的双向数据绑定已经成为了一个非常容易考到的点,即使不能当场写出来,至少也要能说出原理.本篇文章中我将会仿照vue写一个双向数据绑定的实例,名字就叫myVue吧.结合注释,希望 ...

  4. vue实现双向数据绑定的原理

    vue实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个方法重新定义了对象获取属性值(get)和设置属性值(set)的操作来实现的. 在MDN上对该方法的说明是:O ...

  5. 浅析vue的双向数据绑定

    vue 的双向数据绑定是基于es5的 object对象的defineProperty属性,重写data的set和get函数来实现的.1.defineProperty 数据展示 Object.defin ...

  6. vue的双向数据绑定实现原理

    在目前的前端面试中,vue的双向数据绑定已经成为了一个非常容易考到的点,即使不能当场写出来,至少也要能说出原理.本篇文章中我将会仿照vue写一个双向数据绑定的实例,名字就叫myVue吧.结合注释,希望 ...

  7. 原生js实现数据的双向绑定

    原生js实现数据的双向绑定 需要了解的属性是原色js的Object.definePrototype(obj,pop,descript); obj:被构造的对象 pop:被构造的对象的属性,创建对象或修 ...

  8. 一个关于原生 js 开发一款插件的前端教程

    教程链接: http://www.codeasily.net/course/plugin_course/ 写的不是很好,前面比较松后面比较急,请大家见谅,本人也没多少年前端经验,拿以前写过的教程网站, ...

  9. 原生js实现 vue的数据双向绑定

    原生js实现一个简单的vue的数据双向绑定 vue是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时 ...

随机推荐

  1. vue cli3.0配制axios代理

    今天学习时,想访问网易新闻接口,结果显而易见,因为跨域被浏览器拒绝了. 去网上找一下结果一开始找到的是2.x版本的配置,生硬的放进去,给我各种报错.编译阶段就炸了.浪费好多时间 再按3.0版本去搜索才 ...

  2. sqlserver 知识点

    数据库知识点 1.数据库操作: 增:insert into 表名 values(值1,值2,值3) 删:delete 列名 from 表名 where 条件 改:update 表名 set =值 wh ...

  3. c语言题库---- 函数

    ---恢复内容开始--- 1.编写一个函数,功能为返回两个int类型参数的最大的值 #include <stdio.h>int FindMax( int a, int b); int ma ...

  4. 285款photoshop烟花笔刷

    这是一套非常漂亮的PS烟花笔刷,包含285款不同形状效果的笔刷样式,此套photoshop烟花笔刷非常容易使用,使用可以将它们用作照片叠加,用于数码照片处理,作为游戏或艺术品的视觉效果,以及作为装饰元 ...

  5. Reactor和Proactor

    服务器编程框架 IO处理单元 :处理用户连接,读写网络数据:(单机) :作为接入服务器,实现负载均衡;(集群) 请求队列 :各个单元之间通信的抽象,通常被实现为池的一部分:一个单元通知另外一个单元,或 ...

  6. zabbix升级遇到连接不上数据库的问题

    问题 迁移zabbix-server端时,原来是4.0版本,现在为4.2版本,遇到如下问题       解决办法 update dbversion set mandatory=;        

  7. Spring Cloud(Dalston.SR5)--Config 集群配置中心-加解密

    实际应用中会涉及很多敏感的数据,这些数据会被加密保存到 SVN 仓库中,最常见的就是数据库密码.Spring Cloud Config 为这类敏感数据提供了加密和解密的功能,加密后的密文在传输给客户端 ...

  8. Stripes视图框架实现纯Java代码控制表现层参考文档

    https://blog.csdn.net/boonya/article/details/14101477 Stripes是一个开放源码的Web应用程序框架的基础上的模型 - 视图 - 控制器(MVC ...

  9. 工控随笔_10_西门子_WinCC的VBS脚本_01_基础入门

    很多人都认为VB语言或者VBS脚本语言是一种很low的语言,从心里看不起VB或者VBS, 但是其实VBS不仅可以做为系统管理员的利器,同样在工控领域VBS语言大有用武之地. 西门子的WinCC提供了两 ...

  10. 【总结】Java异常分类

    链接:https://www.nowcoder.com/questionTerminal/3ded1983c85c4ae197e005bd31777bc7来源:牛客网 Throwable是所有异常的根 ...