3

我想知道我是否需要公共方法,我需要使用这个

var TestClass = function() {

    this.pub = function() {
              blahblah;
        };

如果需要私有方法(内部方法),我需要使用

var TestClass = function() {

    var pri = function() {
              blahblah;
        };

这是真的?

4

2 回答 2

5

不,这不是真的。内部函数 ( pri) 是一个函数,而不是一个方法。尽管 javascript 中的差异可以忽略不计(因为每个函数都可以用作方法,反之亦然),但您仍然不能将其称为this.pri(),这对于真正的私有方法是可能的。

附带说明一下,尽管其语法与 Java 相似,但 Javascript,尤其是其对象模型,与 Java/C++/C# 有很大不同。特别是,封装等概念在 Javascript 中是不存在的。

于 2012-05-31T17:01:58.260 回答
0

我通常使用这种模式,我没有看到很多人这样做。我这样做是为了避免必须以任何特殊方式订购我的方法。如果一切都是公共的,那么通常必须确保调用的方法在方法调用之前声明

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;
    }    
}
于 2013-07-17T09:51:37.567 回答