简单的双向绑定实现

主要是使用到了订阅者模式.

<!--简单的双向绑定实现-->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <input type="text" data-model="demo">
    <p data-bind="demo" class="demo"></p>
    <h2 data-bind="demo"></h2>
    <span data-bind="demo"></span>
</body>
<script>
    //订阅者模式
    function Observer() {
        this.fns = []
    }

    Observer.prototype = {
        subscribe: function (fn) {
            this.fns.push(fn)
        },
        unsubscribe: function (fn) {
            this.fns = this.fns.filter(function(item) {
                return item !== fn
            })
        },
        publish: function (data, thisObj) {
            var _this = thisObj || this
            this.fns.forEach(function(item) {
                item.call(_this, data)
            })
        }
    }
    var o = new Observer
        
    var subscriber = function (data) {
        var i = document.querySelectorAll('*[data-bind="demo"]').length
        while (i--) {
            document.querySelectorAll('*[data-bind="demo"]')[i].innerHTML = data
        }
    }
    o.subscribe(subscriber)

    document.querySelector('*[data-model="demo"]').addEventListener('input', function(e) {
        e.preventDefault()
        o.publish(document.querySelector('*[data-model="demo"]').value)   
    })
</script>
</html>

这里订阅者模式还可以完善,引入"话题"参数,使得订阅者可以订阅不同的"话题",对应到双向绑定demo中,监听多处data-model

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 179,057评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,568评论 19 139
  • 我的github: vue双向绑定原理 MVC模式 以往的MVC模式是单向绑定,即Model绑定到View,当我们...
    KlausXu阅读 45,414评论 7 90
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 15,358评论 4 61
  • 行动营第二天 《金字塔原理》作者 芭芭拉·明托 美国 01.在工作或者生活中我们很容易遇到一些比较散乱的信...
    水掰掰213阅读 578评论 0 0

友情链接更多精彩内容