PHP设计模式之JS实现观察者模式 c 观察者模式 android 观察者模式 ios 观察者模
观察者模式 Observer
实现目标:变换select框来变动内容区和广告区
一般思路
1:判断选中的值
2:顺序下来,根据值,修改内容区域
3:再修改广告区域.
<code><span>if</span>(v == <span>'男'</span>) <span>{ 内容区背景变灰 广告区内容变成男人话题 }</span><span>else</span><span>if</span>(v == <span>'女'</span>)<span>{ 内容区背景变粉 广告区内容变成女人话题 }</span></code>
那么问题有哪些:
1:让你选择时引起3个区域的变化,是否要修改if/elseif部分
2:如果选择女性样式,但不要变粉,现在流行变紫色,是否又要修改if elseif部分?
问题在于: 控制逻辑与被操作对象耦合严重.
这是就需要观察者模式
js实现观察者模式
我们让div对象观察select的变化,select变化,就会通知到这两个对象。并引起这2个对象的变化,实现观察者模式。
下边是解决效果
select对象负责attach,detach,notifyObservers,与具体的对象变化解耦。
1.index.html
<code><span>body</span>><span>select</span><span>name</span>=<span>''</span><span>id</span>=<span>""</span>><span>option</span><span>value</span>=<span>'male'</span>>男士风格<span><span>option</span>></span><span>option</span><span>value</span>=<span>'female'</span>>女士风格<span><span>option</span>></span><span><span>select</span>></span><span>input</span><span>type</span>=<span>'button'</span><span>value</span>=<span>"观察学习区"</span><span>onclick</span>=<span>"t1();"</span>><span>input</span><span>type</span>=<span>'button'</span><span>value</span>=<span>"不再观察学习区"</span><span>onclick</span>=<span>"t2();"</span>><span>div</span><span>id</span>=<span>'content'</span>>我是内容<span><span>div</span>></span><span>div</span><span>id</span>=<span>'ad'</span>>我是广告<span><span>div</span>></span><span>div</span><span>id</span>=<span>'study'</span>>我是学习区<span><span>div</span>></span><span><span>body</span>></span></code>
2.index.html中js部分
<code><span>script</span>><span><span>//获取对象</span><span>var</span> sel = document.getElementsByTagName(<span>'select'</span>)[<span>0</span>]; <span>//定义方法</span> sel.observers={}; <span>//增加某个方法</span> sel.attach = <span><span>function</span><span>(key,obj)</span>{</span><span>this</span>.observers[key] = obj; } <span>//卸掉某个方法</span> sel.detach = <span><span>function</span><span>(key)</span>{</span><span>delete</span><span>this</span>.observers[key]; } <span>//通知</span> sel.onchange = sel.notify = <span><span>function</span><span>()</span>{</span><span>for</span>(<span>var</span> key <span>in</span><span>this</span>.observers){ <span>this</span>.observers[key].update(<span>this</span>);<span>//去调用对象的update方法</span> } } <span>//客户端</span><span>var</span> content = document.getElementById(<span>'content'</span>); <span>var</span> ad = document.getElementById(<span>'ad'</span>); <span>//内容区变化效果</span> content.update = <span><span>function</span><span>(observer)</span>{</span><span>if</span>(observer.value==<span>'male'</span>){ <span>this</span>.style.backgroundColor=<span>'gray'</span>; }<span>else</span><span>if</span>(observer.value==<span>'female'</span>){ <span>this</span>.style.backgroundColor=<span>'pink'</span>; } } <span>//广告区变化效果</span> ad.update = <span><span>function</span><span>(observer)</span>{</span><span>if</span>(observer.value==<span>'male'</span>){ <span>this</span>.innerHTML=<span>'汽车'</span>; }<span>else</span><span>if</span>(observer.value==<span>'female'</span>){ <span>this</span>.innerHTML=<span>'减肥'</span>; } } <span>//确定谁来监视变化</span> sel.attach(<span>'content'</span>,content); sel.attach(<span>'ad'</span>,ad); study = document.getElementById(<span>'study'</span>); sel.attach(<span>'study'</span>,study);<span>//默认为观察学习区</span> study.update = <span><span>function</span><span>(observer)</span>{</span><span>if</span>(observer.value==<span>'male'</span>){ <span>this</span>.innerHTML=<span>'学习计算机'</span>; }<span>else</span><span>if</span>(observer.value==<span>'female'</span>){ <span>this</span>.innerHTML=<span>'学习减肥'</span>; } } <span>//增加学习区的观察</span><span><span>function</span><span>t1</span><span>()</span>{</span> sel.attach(<span>'study'</span>,study); } <span>//取消学习区的观察</span><span><span>function</span><span>t2</span><span>()</span>{</span> sel.detach(<span>'study'</span>); } </span><span><span>script</span>></span></code>
总结:
- 当有另一个观察对象加入的时候直接添加一个就好
- 降低了主题对象和观察者对象的耦合度
- 好的设计模式不会直接进入你的代码中,而是进入你的大脑中
以上就介绍了PHP设计模式之JS实现观察者模式,包括了观察者模式,设计模式方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在Java框架中,设计模式和架构模式的区别在于:设计模式定义了在软件设计中解决常见问题的抽象解决方案,关注类和对象之间的交互,如工厂模式。架构模式定义了系统结构和模块之间的关系,关注系统组件的组织和交互,如分层架构。

装饰器模式是一种结构型设计模式,允许动态添加对象功能,无需修改原始类。它通过抽象组件、具体组件、抽象装饰器和具体装饰器的协作实现,可以灵活扩展类功能,满足变化的需求。示例中,将牛奶和摩卡装饰器添加到Espresso,总价为2.29美元,展示了装饰器模式在动态修改对象行为方面的强大功能。

1.工厂模式:分离对象创建和业务逻辑,通过工厂类创建指定类型的对象。2.观察者模式:允许主题对象通知观察者对象其状态更改,实现松耦合和观察者模式。

适配器模式是一种结构型设计模式,允许不兼容对象协同工作,它将一个接口转换为另一个,使对象能够顺利交互。对象适配器通过创建包含被适配对象的适配器对象,并实现目标接口,实现适配器模式。在一个实战案例中,通过适配器模式,客户端(如MediaPlayer)可以播放高级格式的媒体(如VLC),尽管其本身仅支持普通媒体格式(如MP3)。

设计模式通过提供可重用和可扩展的解决方案来解决代码维护难题:观察者模式:允许对象订阅事件,并在事件发生时收到通知。工厂模式:提供了一种创建对象的集中式方式,而无需依赖具体类。单例模式:确保一个类只有一个实例,用于创建全局可访问的对象。

TDD用于编写高质量PHP代码,步骤包括:编写测试用例,描述预期功能并使其失败。编写代码,仅使测试用例通过,无需过分优化或详细设计。测试用例通过后,优化和重构代码以提高可读性、可维护性和可扩展性。

Guice框架应用了多项设计模式,包括:单例模式:通过@Singleton注解确保类只有一个实例。工厂方法模式:通过@Provides注解创建工厂方法,在依赖注入时获取对象实例。策略模式:将算法封装成不同策略类,通过@Named注解指定具体策略。

Java框架中使用设计模式的优点包括:代码可读性、可维护性和可扩展性增强。缺点包括:过度使用导致复杂性、性能开销以及学习曲线陡峭。实战案例:代理模式用于延迟加载对象。明智地使用设计模式可充分利用其优势并最小化缺点。
