zoukankan      html  css  js  c++  java
  • 用jquery实现的简单数据双向绑定

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script type="text/javascript" src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    </head>
    <body>
        <input type="text" data-bind-0=name />
        <span data-bind-0="name" ></span>
        <script type="text/javascript">
     
        function DataBinder(object_id){
            var pubSub = jQuery({});
            var data_attr = "bind-"+object_id,
                message = object_id+":change";
            jQuery(document).on("change","[data-" + data_attr +"]",function(evt){
                var $input = jQuery(this);
                pubSub.trigger(message, [$input.attr("data-" + data_attr), $input.val()]);
            });
            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,textarea,select")) {
                        $bound.val(new_val);
                    }
                    else{
                        $bound.html(new_val);
                    }
                });
            });
            return pubSub;
        }
     
        function User(uid){
            var binder = new DataBinder(uid),
                user = {
                    attributes: {},
                    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
                };
           
              return user;
        }
     
        var user = new User(0);
        user.set("name","text");
        
        </script>
    </body>
    </html>
  • 相关阅读:
    django-templates 模板变量
    实用代码
    游戏渠道后台上线
    游戏投放中的-LTV概念与价值
    转字符串格式format技巧
    mysql -数据库设计三范式
    OAuth2.0基本原理及应用
    回调函数
    GitHub 博客园快捷发布工具
    前端react antd加载错误解决
  • 原文地址:https://www.cnblogs.com/catgatp/p/9265437.html
Copyright © 2011-2022 走看看