使用JavaScript设计模式实现的一些示例是什么?
我是一个中等技能的程序员,使用JavaScript,但我不是大师。我知道你可以用它做一些非常强大的事情,除了相当基本的DOM操作之外,我没有看到太多东西。我想知道人们是否可以使用JavaScript提供一些传统设计模式概念的例子,如Factory Method,Singleton等。这些模式会在什么情况下用于网络?使用JavaScript设计模式实现的一些示例是什么?
我只是想添加我从Jonathan Rauch已经推荐的Pro JavaScript Design Patterns中学到的我最喜欢的JavaScript模式。
这是命名空间单例模式。基本上,你可以通过单例创建命名空间,这允许你隐藏外部使用的方法和变量。隐藏/暴露的方法实际上是隐藏的,因为它们是在闭包中定义的。
var com = window.com || {};
com.mynamespace = com.mynamespace || {};
com.mynamespace.newpackage = (function() {
var myPrivateVariable = "hidden";
var myPublicVariable = "exposed";
function myPrivateMethod() {
return "also hidden";
}
function myPublicMethod() {
return "also exposed";
}
return {
myPublicMethod: myPublicMethod,
myPublicVariable: myPublicVariable
};
})();
我怀疑他们能 - 这里是单身的例子:
Nickolay谈到了这一点,但设计模式是不是有大幅差异的语言之间是一致的。我曾阅读过(并同意)设计模式常常是语言中缺少功能的标志。
作为一个很好的例子,“工厂”模式是在一些语言完全没有必要,把Ruby我想到的例子(因为对象的构造就是在类实例的方法):
# create a factory for MyObject
my_factory = MyObject
instance_1 = my_factory.new
# change the factory to another class
my_factory = MyOtherObject
instance_2 = my_factory.new
无论何时您将设计模式应用于与最初开发的语言不同的语言,请确保您考虑是否真的有必要,以及您可以通过可用的新语言功能改进它的方式。设计模式只是一个指南,你应该总是考虑你打算使用的模式是否真的需要这种模式,或者是否可以在你的案例中以更好的方式采用。
我最近使用Bernie's Better Animation Class是大量使用了Strategy设计模式。伯尼在描述为什么应该使用策略模式方面做得非常出色,但遗憾的是并没有准确解释代码是如何工作的。然后,再次使用Design Patterns参考时,请查看animator.js中的代码和注释,以便了解如何使用策略模式。
例子:
// This object controls the progress of the animation
ex1 = new Animator();
// The Animator's subjects define its behaviour
ex1.addSubject(updateButton);
function updateButton(value) {
$('ex1Button').innerHTML = "Progress: " + Math.round(value * 100) + "%";
}
// now click below: each click to the button calls ex1.toggle()
我想在此补充在我研究的是有关双方在C#和JavaScript设计模式的讨论一组。在会议期间对我来说什么是奇特的事情,就是C#人用JavaScript编写代码,而用JavaScript编写相同的代码。 在我离开会议之后,我尝试在家里学习更多,并在这里为C#和JavaScript在这里写作 http://tech.wowkhmer.com/category/Design-Patterns.aspx。
有一个很好的免费在线图书由阿迪·奥斯马尼,引进的Javascript设计模式:在回答Essential JavaScript Design Patterns For Beginners, Volume 1
它应该是`com.mynamespace.newpackage =(function(){...}())`?只是好奇,因为JSLint抱怨。 :) – 2010-06-02 16:12:29
@Brian M. Hunt:我一直认为它是我写的,但你的方式似乎可以在Chrome和Firefox中使用,但不知道IE和其他人。无论如何,一些parens是必要的,否则应用函数的parens被报告为语法错误。 – 2010-06-03 21:59:33