我想知道我是否需要公共方法,我需要使用这个
var TestClass = function() {
this.pub = function() {
blahblah;
};
如果需要私有方法(内部方法),我需要使用
var TestClass = function() {
var pri = function() {
blahblah;
};
这是真的?
我想知道我是否需要公共方法,我需要使用这个
var TestClass = function() {
this.pub = function() {
blahblah;
};
如果需要私有方法(内部方法),我需要使用
var TestClass = function() {
var pri = function() {
blahblah;
};
这是真的?
不,这不是真的。内部函数 ( pri
) 是一个函数,而不是一个方法。尽管 javascript 中的差异可以忽略不计(因为每个函数都可以用作方法,反之亦然),但您仍然不能将其称为this.pri()
,这对于真正的私有方法是可能的。
附带说明一下,尽管其语法与 Java 相似,但 Javascript,尤其是其对象模型,与 Java/C++/C# 有很大不同。特别是,类和封装等概念在 Javascript 中是不存在的。
我通常使用这种模式,我没有看到很多人这样做。我这样做是为了避免必须以任何特殊方式订购我的方法。如果一切都是公共的,那么通常必须确保调用的方法在方法调用之前声明
var person = new Person("Mo", "Yo");
person.getFullname();
person.getFirstname();
person.getLastname();
function Person(firstname, lastname) {
var firstname, lastname;
(function constructor(){
setFirstname(firstname);
setLastname(lastname)
})();
this.getFullname = getFullname; // Makes getFullName() public
function getFullname() {
// Will allow you to order method in whatever order you want.
// If we where to have it as just this.getFullname = function () {...} and same for firstname
// as it is normally done, then this.getFirstname would have to be placed before this method.
// A common pain in the ass, that you cannot order methods as you want!
return getFirstname() + ", " + getLastname();
}
this.getFirstname = getFirstname;
function getFirstname() {
return firstname;
}
function setFirstname(name){
firstname = name;
}
this.getLastname = getLastname;
function getLastname() {
return lastname;
}
function setLastname(name) {
lastname = name;
}
}