函数声明提前

函数声明、函数表达式

  • 函数声明会提前,而函数表达式是在运行时进行赋值。
  • 函数会首先被提升,然后才是变量。也就是说,同一作用域下提前,函数会在更前面。
  • 【注】 相同的变量名声明会被直接忽略,所以下方 函数声明不论放在哪里,第一个 Foo()都输出 1
Foo(); // 1 ,因为函数声明提前了,所以为 1
// 函数声明
function Foo() {
  console.log(1);
}

// 函数表达式 (算是变量声明 Foo,但由于Foo已经声明过了,所以忽略。真正执行时在覆盖)
var Foo = function () {
  console.log(2);
};

Foo(); // 2 ,因为后来被 函数表达式 覆盖了,所以为2

ES5 怎么搞类?

var Person = function (name, age) {
  //实例共有属性
  this.name = name;
  //实例共有方法
  this.sayName = function () {
    console.log(this.name);
  };
  //静态私有属性(只能用于内部调用)
  var home = "China";
  //静态私有方法(只能用于内部调用)
  function sayHome() {
    console.log(home);
  }
  //构造器
  this.setAge = function (age) {
    console.log(age + 12);
  };
  this.setAge(age);
};

//静态方法(只能被类来访问)
Person.sayAge = function () {
  console.log("your age is 12");
};
//静态属性(只能被类来访问)
Person.drink = "water";
//静态共有方法(类和实例都可以访问)
Person.prototype.sayWord = function () {
  console.log("ys is a boy");
};
posted @ 2020-06-05 18:23  彭尼玛  阅读(291)  评论(0编辑  收藏  举报