js实现观察者模式风格替换
如下图,我们看到两种风格:在选择男士时,页面颜色为黑色;在选择女士时,页面颜色为粉红色。
主要可以分为两类:
下拉框 ---》 被观察者
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实现观察者模式风格替换的更多相关文章
- JS实现IOS风格对话框 jquery / zepto
Alert alert("这个是一个alert弹窗"); Alert 自定义参数 alert({ content: "自定义alert弹窗", btnText: ...
- 使用 iosOverlay.js 创建 iOS 风格的提示和通知
iosOverlay.js 用于在 Web 项目中实现 iOS 风格的通知和提示效果.为了防止图标加载的时候闪烁,你需要预加载的图像资源.不兼容 CSS 动画的浏览器需要 jQuery 支持.浏览器兼 ...
- js用replaceAll全部替换的方法
1 前言 js中字符串整体替换,只有自带的replace,并没有replaceAll,如果我们需要把字符串中的字符统一替换,可以用正则表达式,由于经常使用就在String直接加个原生方法,方便调用. ...
- js设计模式-观察者模式
定义: 观察者模式又叫发布订阅模式,它定义了对象间的一种一对多的依赖关系.观察者模式让两个对象松耦合地联系在一起,虽然不太清楚彼此的细节,但这不影响他们之间的互相通信. 思路 定义一个对象,在对象中实 ...
- js中字符串全部替换
废话不多说,直接发结果 在js中字符串全部替换可以用以下方法: str.replace(/需要替换的字符串/g,"新字符串") 比如: "yyyy-MM-dd-hh-mm ...
- js使用占位符替换字符串
js使用占位符替换字符串是一个ES6中的模版字符串语法. 在``中使用 ${} var a = 5; var b = 10; console.log(`Fifteen is ${a + b} and ...
- JS 正则查找与替换
JS正则查找与替换 一.前提/背景 今天遇到个问题,需要替换字符串中部分字符,这些字符相对整个字符串而言,与其他子字符串类似,无法单独提出:重要的是,该字符串是动态的生成的,就像我们日常看到的网页Ur ...
- 谈谈JS的观察者模式(自定义事件)
呼呼...前不久参加了一个笔试,里面有一到JS编程题,当时看着题目就蒙圈...后来研究了一下,原来就是所谓的观察者模式.就记下来...^_^ 题目 [附加题] 请实现下面的自定义事件 Event 对象 ...
- js实现观察者模式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- angular4(2-2)angular脚手架引入第三方类库(swiper)
试了好多方法,npm install 方法失败了,下载到本地是可以使用的: 将swiper文件放到assets文件下: 项目目录下:(命令行) 因为ts并不能准确识别js语法,所以需要用ts中的int ...
- jQuery EasyUI 右键菜单--关闭标签/选项卡
目录结构: noContextMenu.js 文件内容如下: $(function(){ //屏蔽右键菜单 $(document).bind("contextmenu", func ...
- Android集成第三方微信登录
第一步: 在微信开放平台创建安卓应用,需要输入的包名和签名就不用再提吧,不知道的自行百度. 应用创建完毕后会得到两个值:AppID.AppSecret,用这两个值来请求微信. 然后去微信开放平台的资源 ...
- Servlet学习(九)——request
request运行流程在Servlet学习(四)——response已介绍,不再赘述 1.通过抓包工具获取Http请求 因为request代表请求,所以我们可以通过该对象分别获得Http请求的请求行, ...
- hiho1605 - 递推+1000000000=矩阵快速幂
题目链接 题目大意 小Hi最近对生成树(包含所有顶点的联通无环子图.)非常的感兴趣,他想知道对于特定的简单平面无向图是不是存在求生成树个数的简单方法. 小Hi定义了这样的图:一个以{0,1,2……n} ...
- lua_pcall与lua_call之间的区别
lua_pcall与lua_call之间的区别 定义: void lua_call (lua_State *L, int nargs, int nresults); int lua_pcall (lu ...
- 学习Keras:《Keras快速上手基于Python的深度学习实战》PDF代码+mobi
有一定Python和TensorFlow基础的人看应该很容易,各领域的应用,但比较广泛,不深刻,讲硬件的部分可以作为入门人的参考. <Keras快速上手基于Python的深度学习实战>系统 ...
- 红黑树(RBTREE)之上-------构造红黑树
该怎么说呢,现在写代码的速度还是很快的,很高兴,o(^▽^)o. 光棍节到了,早上没忍住,手贱了一般,看到*D的优惠,买了个机械键盘,晚上就到了,敲着还是很舒服的,和老婆炫耀了一把哈哈. 光棍节再去* ...
- nodejs 守护进程运行
有四种方法: 1.forever forver start bin/www 2.pm2 pm2 strat bin/www 3.node自身进程保护 nohup node /bin/www > ...
- (51) magento集成增加到款通知
这篇主要讲述如何二开增加自己的功能,我没有继承方式二开,习惯是不好的,直接改了原来的模块. 达到效果就这样,当在网站支付成功,会同步到ERP系统中.下面来讲述实现过程 建立文件 payment_not ...