看apply函数的理论知识的时候觉得很简单,但后来看到书上一段小代码,发现之前并没有深刻地理解这个函数,这里记下来做个笔记.

代码如下:

function r(x){
  return x;
}
function f(x){
  x[0] =x[0]+">";
  return x;
}
function o(){
  var temp = r;

  r = function(){

    return temp.apply(this,f(arguments));

  }
}

function a(){
  o();
  document.write(r("="));
}

for (var i = 0; i <10; i++) {

   a();

   document.write("</br>")
 }

运行结果如下:

一开始没有想明白为什么是先打印=再打印>,后来对代码进行断点处理之后,才发现其中的奥妙.

function r(x){
document.write("6");
return x;
}
function f(x){
x[0] =x[0]+">";
document.write("5");
for (var i = 0; i < arguments.length; i++) {
document.write(x[i]);
};
return x;
}
function o(){
var temp = r;

document.write("1");

r = function(){
document.write("4");
return temp.apply(this,f(arguments));

}
document.write("2");
}

function a(){
//document.write(r("="));
o();
document.write("3");
document.write(r("="));
}

a();
document.write("<br><br>");

// for (var i = 0; i <10; i++) {
// a();

// document.write("</br>")
// }

按照上文的提示,代码运行顺序是这样的:

运行o()

  将r函数赋值给temp;

  打印1;

  重写r函数,不执行;

  打印2;

回到a函数,打印3;

执行r("=")函数;

r函数在o()中被改写,打印4;

返回一个temp函数

  返回值中.先执行f(arguments),

    打印5

    由于此时的arguments为"=",故f("=")的执行结果为返回 =>

  执行函数 temp(this,"=>")

    打印6

    返回 =>

所以最后的结果为123456=>

注意:

  temp = r 是对函数的一个赋值;

  r = function(){...} 只是写了一个函数并没有调用他,故此时不执行该函数;

  apply函数中若第一个参数为this,即为调用他的函数,若为其他对象或函数,则执行对象为第一个参数所设置的对象,第二个参数是一个arguments数组,若为函数,则arguments是函数的返回值.

转载于:https://www.cnblogs.com/julyys/p/4483685.html

一个apply的实例相关推荐

  1. Connected to an idle instance.连接到一个空的实例

    执行  sqlplus >  startup, 解决. 博主刚开始用Linux装完oracle的时候,装了一整天,开心的不行,最后使用命令时出现了Connected to an idle ins ...

  2. SDK Instrumentation创建一个Note的实例

    除了高层框架如Robotium的solo,我们也可以直接调用SDK底层的提供的Instrumentation的API来实现如前几篇文章描述的创建一个note的功能.总所周知之Robotium就是基于I ...

  3. 静态方法是一种特殊的成员方法,它不属于类的某一个具体的实例。

    静态方法是一种特殊的成员方法,它不属于类的某一个具体的实例. 非静态方法可以访问类中的任何成员,而静态只能访问类中的静态成员. C# code class A { int x; static int ...

  4. 深入实践Spring Boot1.3.2 一个简单的实例

    1.3.2 一个简单的实例 Spring Boot的官方文档中提供了一个最简单的Web实例程序,这个实例只使用了几行代码,如代码清单1-3所示.虽然简单,但实际上这已经可以算作是一个完整的Web项目了 ...

  5. ​iOS 9音频应用播放音频之第一个ios9音频实例2

    ​iOS 9音频应用播放音频之第一个ios9音频实例2 ios9音频应用关联 iOS9音频应用中对于在主视图上添加的视图或控件,在使用它们时必须要与插座变量进行关联.ios9插座变量其实就是为主视图中 ...

  6. iOS 9音频应用播放音频之第一个ios9音频实例

    iOS 9音频应用播放音频之第一个ios9音频实例 第一个ios9音频实例 为了让开发者可以对上面的内容有更加深入的了解,本节将实现播放音频的第一个实例.在此实例中会涉及到项目的创建.界面设计.关联以 ...

  7. 一个Win32 API实例类(代码收集)

    最近看到别人代码中一个很好的功能类,该类是一个Win32 API实例类,该类功能包括:同一程序禁止启动多次:获取任意窗体:恢复窗体状态:设置窗体焦点等. 该类很实用,与大家分享一下:  1     / ...

  8. 很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据。 如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置 文件内容的对象,则在系统运行中,有 很多地方都需

      很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据.   如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置文件内容的对象,则在系统运行中,有很多地方 ...

  9. 每个施加在HTML元素上的Angular Directive,运行时都会生成一个新的实例

    每个施加在HTML元素上的Directive,运行时都会生成一个新的实例. 这些实例的ngOnInit hook执行完毕之后,再统一支持ngAfterViewInit: 上图这个focus-lock ...

最新文章

  1. Nature:AI为什么总是歧视重重?
  2. 空扫描Idle Scanning
  3. ubuntu20输入法qiehuan_Ubuntu20.04安装搜狗输入法
  4. webpack-安装
  5. 页面无法正常显示,淘宝又崩了!周五上班摸鱼被发现...
  6. 真实版“删库跑路”?程序员蓄意破坏线上生产环境!
  7. js实现字符串的加密与解密
  8. box-sizing布局(简要介绍)
  9. 麦亡9什么时候能装鸿蒙系统,距断供不到10天 麒麟9000即将绝版 华为大招来了:不止鸿蒙2.0...
  10. zookeeper核心原理(Watcher、事件和状态)
  11. Idea插件 Sonar
  12. julia语言 python解释器_深入Python解释器源码,我终于搞明白了字符串驻留的原理...
  13. 2021年中职“网络安全“江西省赛题—B-8:Web渗透测试
  14. 语音视频自动生成字幕功能介绍
  15. 简单粗暴讲述自动化仓储系统
  16. 产品目标拆解:结构化思维
  17. 从URDF到KDL(C++Python)
  18. SDUT 2021 Spring Individual Contest(for 20) - 1
  19. 软件架构设计与需求分析方法论
  20. java窗口弹出的位置_java的窗口弹出和动手动脑

热门文章

  1. SpringBoot 多环境配置
  2. vue-router 传递参数的几种方式
  3. mongdb安装配置
  4. webstorm最新版破解教程及汉化教程(也是看别人的)
  5. 在vue中使用express-mock搭建mock服务
  6. 系统磁盘空间满的一个问题
  7. Java回调函数使用
  8. 跟2G说再见?这些IoT“钉子户”表示做不到……
  9. h5文字垂直居中_CSS实现居中的几种方式你都了解吗?
  10. 在MySql中,这四种方法可以避免重复插入数据!