最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

JS原生数据双向绑定实现代码

来源:懂视网 责编:小采 时间:2020-11-27 22:32:45
文档

JS原生数据双向绑定实现代码

JS原生数据双向绑定实现代码:代码如下: <span style=font-family:Times New Roman;font-size:14px; deep=7><!DOCTYPE html> <html lang=en> <head> <meta charset=UTF-8> <title&
推荐度:
导读JS原生数据双向绑定实现代码:代码如下: <span style=font-family:Times New Roman;font-size:14px; deep=7><!DOCTYPE html> <html lang=en> <head> <meta charset=UTF-8> <title&

代码如下:

<span style="font-family:Times New Roman;font-size:14px;" deep="7"><!DOCTYPE html> 
<html lang="en"> <head> 
 <meta charset="UTF-8"> 
 <title>Demo</title> 
 <script> 
 function DataBinder( object_id ) { 
 // Create a simple PubSub object 
 var pubSub = { 
 callbacks: {}, 
 on: function( msg, callback ) { 
 this.callbacks[ msg ] = this.callbacks[ msg ] || []; 
 this.callbacks[ msg ].push( callback ); 
 }, 
 publish: function( msg ) { 
 this.callbacks[ msg ] = this.callbacks[ msg ] || []; 
 for ( var i = 0, len = this.callbacks[ msg ].length; i < len; i++ ) { 
 this.callbacks[ msg ][ i ].apply( this, arguments ); 
 } 
 } 
 }, 
 data_attr = "bind-" + object_id, 
 message = object_id + ":input", 
 timeIn; 
 changeHandler = function( evt ) { 
 var target = evt.target || evt.srcElement, // IE8 compatibility 
 prop_name = target.getAttribute( data_attr ); 
 if ( prop_name && prop_name !== "" ) { 
 clearTimeout(timeIn); 
 timeIn = setTimeout(function(){ 
 pubSub.publish( message, prop_name, target.value ); 
 },50); 
 } 
 }; 
 // Listen to change events and proxy to PubSub 
 if ( document.addEventListener ) { 
 document.addEventListener( "input", changeHandler, false ); 
 } else { 
 // IE8 uses attachEvent instead of addEventListener 
 document.attachEvent( "oninput", changeHandler ); 
 } 
 // PubSub propagates changes to all bound elements 
 pubSub.on( message, function( evt, prop_name, new_val ) { 
 var elements = document.querySelectorAll("[" + data_attr + "=" + prop_name + "]"), 
 tag_name; 
 for ( var i = 0, len = elements.length; i < len; i++ ) { 
 tag_name = elements[ i ].tagName.toLowerCase(); 
 if ( tag_name === "input" || tag_name === "textarea" || tag_name === "select" ) { 
 elements[ i ].value = new_val; 
 } else { 
 elements[ i ].innerHTML = new_val; 
 } 
 } 
 }); 
 return pubSub; 
 } 
 function DBind( uid ) { 
 var binder = new DataBinder( uid ), 
 user = { 
 // ... 
 attributes: {}, 
 set: function( attr_name, val ) { 
 this.attributes[ attr_name ] = val; 
 // Use the `publish` method 
 binder.publish( uid + ":input", attr_name, val, this ); 
 }, 
 get: function( attr_name ) { 
 return this.attributes[ attr_name ]; 
 }, 
 _binder: binder 
 }; 
 // Subscribe to the PubSub 
 binder.on( uid + ":input", function( evt, attr_name, new_val, initiator ) { 
 if ( initiator !== user ) { 
 user.set( attr_name, new_val ); 
 } 
 }); 
 return user; 
 } 
 </script> 
</head> 
<body> 
<input type="text" bind-1="name" /> 
<span bind-1="name"></span> 
<script> 
 var DBind = new DBind( 1 ); 
 DBind.set( "name", "" ); 
</script> 
</body> 
</html>
</span> 

效果示例:

总结

以上所述是小编给大家介绍的JS原生数据双向绑定实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

JS原生数据双向绑定实现代码

JS原生数据双向绑定实现代码:代码如下: <span style=font-family:Times New Roman;font-size:14px; deep=7><!DOCTYPE html> <html lang=en> <head> <meta charset=UTF-8> <title&
推荐度:
标签: 实现 js 代码
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top