了解神奇的this

this的用法
  在函数中this到底取何值,是在函数真正被调用执行的时候确定的,函数定义的时候确定不了.

  因为this的取值是执行上下文环境的一部分,每次调用函数,都会产生一个新的执行上下环境.举例说明

1. 构造函数之this

  function Foo() {
      this.name = "zhangsan";
      this.age = 20;
      console.log(this);
  }
  var f1 = new Foo();

说明:
 1. 如果函数作为构造函数使用,那么其中的this就代表它new出来的对象
 2. 如果函数作为普通函数调用,这种情况this是指window.

  function Foo() {
      this.name = "zhangsan";
      this.age = 20;
      console.log(this);
  }
  Foo();
  console.log(window.name);
  console.log(window.age);

2. 函数作为对象的一个属性
  如果函数作为对象的一个属性时,并且作为对象的一个属性被调用时,函数中的this指向该对

  var obj = {
      x:10,
      fn:function() {
          console.log(this.x);
      }
  };
  obj.fn();

  var obj = {
      x:10,
      fn:function() {
          console.log(this.x);
      }
  };
  var obj1 = {
      x:20
  };
  obj1.fn = obj.fn;
  obj1.fn();

3. 函数用call或apply调用
  当一个函数被call和apply调用时,this的值就去传入的对象的值

  var test = "Tony";
  function doSomething() {
      console.log(this.test);
  }
  var obj = {
      test:"Tom"
  };
  doSomething();
  doSomething.call(obj);//doSomething中的this指向obj

4. 全局&普通函数的调用
  在全局环境下,this指向的是window对象

    console.log(this === window);//true

  普通函数调用时,其中的this也是指向的window对象

  var x = 10;
  var fn = function() {
      console.log(this);//window
      console.log(this.x);//10
  };
  fn();
注意以下情况:虽然函数f是在obj对象内部定义的,但是他任然是一个普通函数,this指向的还是window对象.

  var x = 20;
  var obj = {
      x:10,
      fn:function() {
          function f() {
              console.log(this);
              console.log(this.x);
          }
          f();
      }
  };
  obj.fn();

5. 构造函数prototype
  this代表的是当前对象的值,不仅仅是在构造函数的prototype,即便是在整个原型链中.

  function Fn(name, age) {
      this.name = name;
      this.age = age;
  }
  Fn.prototype.sayName = function() {
      console.log(this.name);
  };
  var f1 = new Fn("zhangsan", 20);
  console.log(f1.name);

时间: 2024-12-20 15:06:56

了解神奇的this的相关文章

东方14模拟赛之noip2015/day1/3/神奇的幻方

总时间限制:  10000ms 单个测试点时间限制:  1000ms 内存限制:  128000kB 描述 幻方是一种很神奇的N*N 矩阵:它由数字 1,2,3, … …,N*N 构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将 1 写在第一行的中间. 之后,按如下方式从小到大依次填写每个数K(K= 2,3, …,N*N ): 若 (K−1) 在第一行但不在最后一列,则将K填在最后一行,(K−1) 所在列的右一列: 若 (K−1) 在最

【第二章】神奇的张大炮

一只剃了毛的猫崽和一条受了伤的手臂能做什么? 十个人里有九个人觉得剃了毛的猫崽应该埋到土里喂蚯蚓. 十个人里有九个人认为手臂受了伤应该去医院. 可是偏偏十个人里还剩下一个,这第十位不但认为剃了毛的猫崽和受了伤的手臂可以做文章,简直可以做大文章. 不但可以做大文章,简直还可以赚大钱. 最关键的是,他不但做了大文章,还赚了大钱. 因为这第十位不是别人,就是这位神奇的张大炮. 当一个人被认为神奇的时候,他就必定有了称得上神奇的地方. 张大炮就有张大炮神奇的地方. 张大炮神奇的地方实在不少,他的脏实在只

AC日记——神奇的幻方 洛谷 P2615(大模拟)

题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1写在第一行的中间. 之后,按如下方式从小到大依次填写每个数K(K=2,3,…,N*N): 1.若(K−1)在第一行但不在最后一列,则将K填在最后一行,(K−1)所在列的右一列: 2.若(K−1)在最后一列但不在第一行,则将K填在第一列,(K−1)所在行的上一行: 3.若(K−1)在第一行最后一列,则将K填在(K−1)

一个神奇的递推公式--转自2108

志远兄发现了一个神奇的递推公式, 某些递推的题目可以看作, 一个个上三角阵, 而问题的解为(1,1) 至 (n,n) 的路径个数, 废话不多说, 上题上代码 以下转自http://www.cnblogs.com/--ZHIYUAN/p/5971367.html 小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 9447    A

JAVA注释的另一种神奇用法

每个JAVA程序员在写程序的时候一定都会用到注释,本篇博客不是讲怎么定义注释,而是说明注释神奇的一种写法. 1 /** 2 * 这是一个测试类 3 */ 4 public class Test { 5 /** 6 * 程序的入口 7 */ 8 public static void main(String[] args) { 9 new Test(); 10 } 11 } 以上是两个普通的多行注释,在IDEA的环境下,选中方法或者类名,按住Ctrl+Q(Eclipse开发环境下直接按住Ctrl然后

NOIP 2015普及组复赛Day1 T1 == Codevs4510 神奇的幻方

时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题目描述 Description: 幻方是一种很神奇的N∗N矩阵:它由数字 1,2,3, … … ,N∗N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将 1写在第一行的中间.之后,按如下方式从小到大依次填写每个数(K= 2,3, … ,N∗N ): 1.若 (K−1)在第一行但不在最后一列,则将 填在最后一行,(K−1)所在列的右一列: 2.若 (K

神奇的幻方【够造奇数阶的魔方阵】

http://noi.openjudge.cn/ch0108/22/ 总时间限制:  1000ms 内存限制:  65535kB 描述 幻方是一个很神奇的N*N矩阵,它的每行.每列与对角线,加起来的数字和都是相同的.我们可以通过以下方法构建一个幻方.(阶数为奇数)1.第一个数字写在第一行的中间2.下一个数字,都写在上一个数字的右上方:    a.如果该数字在第一行,则下一个数字写在最后一行,列数为该数字的右一列    b.如果该数字在最后一列,则下一个数字写在第一列,行数为该数字的上一行    

神奇的scanf

神奇的scanf 作为标准输入输出函数组中的一个重要的输入的函数,scanf/sscanf/vscanf函数和printf/sprintf/vsprintf有个重要的区别:如果格式参数和后面的参数不匹配,printf系列函数可能会导致打印出的格式或者数据不是自己期望的 ,而scanf系列函数如果格式参数和后面的参数不匹配,可能导致有待输入的参数附近的内存发生变化,甚至导致程序崩溃. 以下面的函数为例: 8 #include<stdio.h> 9 #include<string.h>

神奇的网页阅读模式

今天突然之间发现了一个网页中含有阅读模式,打开之后网页中的所有广告被屏蔽掉了,确实非常的舒服,看网页的感觉就像看书一样.可以这个功能究竟是什么回事呢? 操作步骤: 1.在浏览器中输入,about:config 2.搜索 reader.parse-on-load.enabled,确定值为“true”即可 注意事项: 有部分人,可能会神奇的发现有些页面是看不到阅读模式的,这是什么原因呢?这是因为该页面本身不支持阅读模式导致,并非浏览器本身的问题.目前火狐.谷歌等浏览器好像都支持这个功能了.其实这个功

2015年 day1.1 神奇的幻方

神奇的幻方 题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1写在第一行的中间. 之后,按如下方式从小到大依次填写每个数K(K=2,3,…,N*N): 1.若(K−1)在第一行但不在最后一列,则将K填在最后一行,(K−1)所在列的右一列: 2.若(K−1)在最后一列但不在第一行,则将K填在第一列,(K−1)所在行的上一行: 3.若(K−1)在第一行最后一列,则将K填