Last active
January 1, 2016 08:39
-
-
Save luokebi/8120025 to your computer and use it in GitHub Desktop.
jquery two-way data bind demo
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!doctype html> | |
<html lang="en"> | |
<head> | |
<meta charset="UTF-8"> | |
<title>Document</title> | |
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> | |
</head> | |
<body> | |
<input type="text" data-bind-123="name"> | |
<script type="text/javascript"> | |
function DataBinder(object_id){ | |
//使用一个jQuery对象作为简单的订阅者发布者 | |
var pubSub = jQuery({}); | |
//我们希望一个data元素可以在表单中指明绑定:data-bind-<object_id>="<property_name>" | |
var data_attr = "bind-" + object_id, | |
message = object_id + ":change"; | |
//使用data-binding属性和代理来监听那个元素上的变化事件 | |
// 以便变化能够“广播”到所有的关联对象 | |
jQuery(document).on("change","[data-" + data_attr + "]",function(evt){ | |
var input = jQuery(this); | |
pubSub.trigger(message, [input.data(data_attr), input.val()]); | |
}); | |
//PubSub将变化传播到所有的绑定元素,设置input标签的值或者其他标签的HTML内容 | |
pubSub.on(message,function(evt,prop_name,new_val){ | |
jQuery("[data-" + data_attr + "=" + prop_name + "]").each(function(){ | |
var $bound = jQuery(this); | |
if($bound.is("input,text area,select")){ | |
$bound.val(new_val); | |
}else{ | |
$bound.html(new_val); | |
} | |
}); | |
}); | |
return pubSub; | |
} | |
function User(uid){ | |
var binder = new DataBinder(uid), | |
user = { | |
attributes: {}, | |
//属性设置器使用数据绑定器PubSub来发布变化 | |
set: function(attr_name,val){ | |
this.attributes[attr_name] = val; | |
binder.trigger(uid + ":change", [attr_name, val, this]); | |
}, | |
get: function(attr_name){ | |
return this.attributes[attr_name]; | |
}, | |
_binder: binder | |
}; | |
binder.on( uid + ":change", function( evt, attr_name, new_val, initiator ) { | |
if ( initiator !== user ) { | |
user.set( attr_name, new_val ); | |
} | |
}); | |
return user; | |
} | |
var user = new User(123); | |
user.set("name","Wolfgang"); | |
</script> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment