如下图,我们看到两种风格:在选择男士时,页面颜色为黑色;在选择女士时,页面颜色为粉红色。
    主要可以分为两类:
            下拉框 ---》 被观察者
            div   ---》 观察者



面向过程实现风格替换:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
</head>
<style>
    div{
        border: 1px solid #000000;
        width: 400px;
        height:100px;
        margin-top: 5px;
    }
</style>
<body>
<select name="" id="">
    <option value="man" selected>男士</option>
    <option value="woman">女士</option>
</select>
<div id="one"></div>
<div id="two"></div>
<div id="three"></div>
</body>
<script>
    var sel=document.getElementsByTagName('select')[0];
    var one=document.getElementById("one");
    var two=document.getElementById("two");
    one.style.background="black";
    two.innerHTML="i am superman";
    window.onload=function(){
        sel.onchange=function(){
            var sv=sel.value;
            if(sv=="woman"){
                one.style.background="pink";
                two.innerHTML="i am superwoman";
            }else if(sv=="man"){
                one.style.background="black";
                two.innerHTML="i am superman";
            }
        }
    }
</script>
</html>

观察者模式实现风格替换:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
</head>
<style>
    div{
        border: 1px solid #000000;
        width: 400px;
        height:100px;
        margin-top: 5px;
    }
</style>
<body>
<select name="" id="">
    <option value="man" selected>男士</option>
    <option value="woman">女士</option>
</select>
<div id="one"></div>
<div id="two"></div>
<!--
    如果新增加一个 div3 就需要修改旧的代码了,可以看出这种方式的扩展性就特别的低。
    因为在面向对象编程中有中思维叫:开闭原则。对于修改是封闭的,对于扩展是开放的。
    解决方案:
          我们可以用观察者模式,解决这一扩展性低问题。
          观察者模式,顾名思义:重点是观察下拉框(被观察者)的改变,
     当下拉框改变时,div(观察者)做出相应改变。
-->
<div id="three"></div>
</body>
<script>
    var sel=document.getElementsByTagName('select')[0];
    var one=document.getElementById("one");
    var two=document.getElementById("two");
    one.style.background="black";
    two.innerHTML="i am superman";
    //定义一个对象,用来存储观察者对象。
    sel.servers={};
    //定义一个添加观察者方法
    sel.attach=function(key,val){
        sel.servers[key]=val;
    };
    //将观察者添加到观察者队列中
    sel.attach("one",one);
    sel.attach("two",two);
    sel.onchange=function(){
        for(var i in this.servers){
            this.servers[i].update(this);
        }
    };
    one.update=function(obj){
        if(obj.value=="man"){
            this.style.background="black";
        }else{
            this.style.background="pink";
        }
    };
    two.update=function(obj) {
        if (obj.value == "man") {
            this.innerHTML = "i am superman";
        } else {
            this.innerHTML = "i am superwoman";
        }
    };
    //当再出现观察者时,我们只需要将观察者添加到观察者队列中。
    //降低了代码的耦合性,增加了代码的扩展性。
    var three=document.getElementById('three');
    sel.attach("three",three);
    three.update=function(obj) {
        if (obj.value == "man") {
            this.innerHTML = "man";
        } else {
            this.innerHTML = "woman";
        }
    };
</script>
</html>

js实现观察者模式风格替换的更多相关文章

  1. JS实现IOS风格对话框 jquery / zepto

    Alert alert("这个是一个alert弹窗"); Alert 自定义参数 alert({ content: "自定义alert弹窗", btnText: ...

  2. 使用 iosOverlay.js 创建 iOS 风格的提示和通知

    iosOverlay.js 用于在 Web 项目中实现 iOS 风格的通知和提示效果.为了防止图标加载的时候闪烁,你需要预加载的图像资源.不兼容 CSS 动画的浏览器需要 jQuery 支持.浏览器兼 ...

  3. js用replaceAll全部替换的方法

    1 前言 js中字符串整体替换,只有自带的replace,并没有replaceAll,如果我们需要把字符串中的字符统一替换,可以用正则表达式,由于经常使用就在String直接加个原生方法,方便调用. ...

  4. js设计模式-观察者模式

    定义: 观察者模式又叫发布订阅模式,它定义了对象间的一种一对多的依赖关系.观察者模式让两个对象松耦合地联系在一起,虽然不太清楚彼此的细节,但这不影响他们之间的互相通信. 思路 定义一个对象,在对象中实 ...

  5. js中字符串全部替换

    废话不多说,直接发结果 在js中字符串全部替换可以用以下方法: str.replace(/需要替换的字符串/g,"新字符串") 比如: "yyyy-MM-dd-hh-mm ...

  6. js使用占位符替换字符串

    js使用占位符替换字符串是一个ES6中的模版字符串语法. 在``中使用 ${} var a = 5; var b = 10; console.log(`Fifteen is ${a + b} and ...

  7. JS 正则查找与替换

    JS正则查找与替换 一.前提/背景 今天遇到个问题,需要替换字符串中部分字符,这些字符相对整个字符串而言,与其他子字符串类似,无法单独提出:重要的是,该字符串是动态的生成的,就像我们日常看到的网页Ur ...

  8. 谈谈JS的观察者模式(自定义事件)

    呼呼...前不久参加了一个笔试,里面有一到JS编程题,当时看着题目就蒙圈...后来研究了一下,原来就是所谓的观察者模式.就记下来...^_^ 题目 [附加题] 请实现下面的自定义事件 Event 对象 ...

  9. js实现观察者模式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. 神经网络预测mnist时候如果不归一化,则准确率仅仅10%下文作者svm也遇到了。

    转自:http://blog.csdn.net/jeryjeryjery/article/details/72649320 这两天用Python来实现手写数字识别,刚开始用原始数据进行训练,结果预测结 ...

  2. zzulioj--1712--神秘的数列(水题)

    1712: 神密的数列 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 122  Solved: 92 SubmitStatusWeb Board De ...

  3. 那些年尝试过的效率工具之Total Commander

    昨天电脑文件很乱,想整理一下发现移动.复制文件要来回目录切换很麻烦,突然就又想起了用Total Commander——简称TC,很久之前尝试过但没坚持使用的工具. 借此机会总结一下自己对TC的认识,后 ...

  4. 搞定ubuntu下环境变量的配置

    Ubuntu Linux系统环境变量配置文件: /etc/profile : 在登录时,操作系统定制用户环境时使用的第一个文件 ,此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. ...

  5. [JZOJ 5905] [NOIP2018模拟10.15] 黑暗之魂(darksoul) 解题报告 (拓扑排序+单调队列+无向图基环树)

    题目链接: http://172.16.0.132/senior/#main/show/5905 题目: oi_juruo热爱一款名叫黑暗之魂的游戏.在这个游戏中玩家要操纵一名有 点生命值的无火的余灰 ...

  6. 访问视频资源报错:Failed to load resource: net::ERR_CONNECTION_RESET

    访问视频资源报错: 浏览器显示:Failed to load resource: net::ERR_CONNECTION_RESET. 原因:公司内部限制了访问外网资源,凡是视频资源都不能访问. 解决 ...

  7. POJ 3617 Best Cow Line 贪心算法

    Best Cow Line Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 26670   Accepted: 7226 De ...

  8. angular 报错笔记

    1.错误信息: Failed to instantiate module app due to: Error: [$injector:unpr] http://errors.angularjs.org ...

  9. Date日期类 Calendar日历类 完成可视化日历

    package com.test; import java.text.DateFormat; import java.text.ParseException; import java.text.Sim ...

  10. Linux部署之批量自动安装系统之测试篇

    1.         客户端从网络启动如下   2.         复制vesamenu.c32文件可解决上面的问题   3.         客户端再次启动   4.         选择第一个进 ...