目录

JS中的作用域和闭包(二)

JS中的作用域和闭包(二)

前篇介绍了基于闭包的作用域特性,那么利用这些特性,在设计开发模型时,我们将有更高阶的抽象和灵活性来处理复杂业务实现。

通过私有化方式,隐藏内部实现

隐藏内部实现,也称为私有化,是一种编程技术,通过限制对代码的访问来保护代码的完整性和稳定性。在某些编程语言中,可以通过访问修饰符(如public、private、protected)来控制对类成员的访问。然而,在一些其他的编程语言中,例如JavaScript,没有内置的访问修饰符,因此需要使用其他技术来实现隐藏内部实现。

在JavaScript中,可以使用函数作用域来实现私有化。函数作用域是指在函数内部定义的变量和函数只能在该函数内部访问,无法从函数外部访问。这意味着在函数内部定义的变量和函数对于外部代码来说是隐藏的,可以被看作是私有的。

例如,下面的代码展示了一个使用函数作用域来实现私有化的例子:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
function Counter() {
  var count = 0;  // count 是私有变量

  function increment() {  // increment 是私有函数
    count++;
    console.log(count);
  }

  this.incrementCount = function() {  // incrementCount 是公共函数
    increment();
  };
}

var counter = new Counter();
counter.incrementCount(); // 输出 1
counter.incrementCount(); // 输出 2

在上面的例子中,count 和 increment 只能在 Counter 函数内部访问,因此它们被视为私有的。incrementCount 是一个公共函数,因为它是通过 this 关键字添加到 Counter 的实例中的,可以从外部访问并调用。由于 count 是私有变量,无法从外部直接访问或修改它,因此只能通过 increment 函数来修改 count。

命名空间Namespace 库通常会在全局作用域中声明一个名字足够独特的变量,通常是一个对象。这个对象 被用作库的命名空间,所有需要暴露给外界的功能都会成为这个对象(命名空间)的属性,而不是将自己的标识符暴漏在顶级的词法作用域中。

命名空间(Namespace)是一种组织代码的方式,可以避免命名冲突和污染全局命名空间。它可以将相关的代码组织在一起,形成一个独立的作用域,从而减少变量和函数之间的命名冲突。

在 JavaScript 中,命名空间可以通过对象字面量来实现。对象字面量是一种创建对象的方式,可以在一对花括号中定义一个包含属性和方法的对象。我们可以把对象字面量作为一个命名空间,将相关的属性和方法都放到这个命名空间中,从而避免全局命名空间的污染。

以下是一个简单的命名空间示例:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
var myNamespace = {
  name: "John",
  age: 30,
  sayHello: function() {
    console.log("Hello, " + this.name + "!");
  }
};

console.log(myNamespace.name); // "John"
console.log(myNamespace.age); // 30
myNamespace.sayHello(); // "Hello, John!"

在上面的代码中,我们创建了一个名为 myNamespace 的命名空间,其中包含了一个 name 属性、一个 age 属性和一个 sayHello 方法。

通过命名空间的方式,我们可以将相关的属性和方法组织在一起,使得代码更加清晰易懂,也能够有效地避免命名冲突。