在 PHP 中,您可以执行以下操作:
class myClass() {
function doSomething(someVar) {
// do something here
}
// etc... (other methods and properties)
}
然后,当然,您可以在实例化类之后调用该方法,如下所示:
$myObj = new myClass();
$myObj->doSomething();
但是您也可以选择将该方法作为独立函数调用,而无需实例化类(但您必须注意该函数中的依赖项),如下所示:
myClass::doSomething();
我相信这是为 C++ 借来的东西...它被称为范围解析运算符(PHP 代码中的 Paamayim Nekudotaim...)
http://en.wikipedia.org/wiki/Scope_resolution_operator#PHP
http://www.php .net/manual/en/language.oop5.paamayim-nekudotayim.php
你会如何在 JavaScript 中做这样的事情?这似乎是不可能的。也许我以错误的方式接近这个,我应该透露我想要实现的目标......
我只是有一个函数,它是这样的:
function submitContactForm(form) {
// pretty JavaScript...
}
我很高兴它是一个功能。但我想实现一个“resetContactForm()”,但希望以某种方式将它附加到 submitConatctForm 函数。
我知道我可能会这样做:
var contactForm = {
"submit" : function(form) {
//...
},
"reset" : function(form) {
//...
}
}
我会这样回答我自己的问题......
但是,除了我不喜欢这种语法并想避免它之外,还有一个事实是上面的结构不能用作类定义,它与 PHP 中的不一样......所以回到最初的问题:有没有办法让 JavaScript 结构同时用作类定义和独立函数的集合?