权威指南上的说法是:可以将call 和apply看做是某个对象的方法,通过调用方法的形式

间接调用函数;需要重点说明是 :通过call和apply 调用的 函数:具体用法---》如下:

1.先说call的用法,call可以接收两个参数,也可能不是两个;第一个参数是要调用函数的

母对象,在函数体内通过this来获得对它的引用;

function a(){
console.log(this); // 输出函数a中的this对象
}

function b(){} // 定义函数b
var obj = {name:'onepixel'}; //定义对象obj

//调用
a();//this代表window对象;
a.call;//本身是一个函数方法//window
console.log(a.call); //function call() { [native code] };
a.call(null); //window 传入null,函数中的this,指向window
a.call(undefined);//window 传入undefined,函数中的this,指向window
a.call(1); //Number 传入数值型,this指向对应的包装类型,Number
a.call(''); //String 传入字符串,this指向string 类型
a.call(true); //Boolean 传入布尔类型,this指向Boolean类型
a.call(b);//function b(){}
a.call(obj); //Object 指向obj;
//call的用法;

可以看到call()中第一个参数出入什么样的参数,this 就指向对应的包装类型;

不传参,或者参数为null,undefined 时,this指向window;

具体用法:

//call的用法;
var m = {
  name:'onepixel',
    say:function(){
    console.log('hi,i am function m!');
    },
  }

  function n(name){
    console.log('post params:'+name);
    console.log('i am '+this.name);
    this.say;
  }
n.call(m,'test');//post params:test
// i am onepixel
//I'm function a! 不知道为什么没有调用;

也就是说n可以通过call来调用M 中的方法; 
//关于appply
//apply和call的唯一区别是第二个参数的传递方式不同,
//apply的第二个参数必须是一个数组,而call允许传递一个参数列表
//值得你注意的是,虽然apply接收的是一个参数数组,但在传递给调用函数时,
//却是以参数列表的形式传递

function f(x,y,z){
console.log(x,y,z)
}
f.apply(undefined,[1,2,3]);//1,2,3

//第一个参数传null或undedined指向window
重点://js中么有继承的概念,call和apply却可以实现;

function Animal(name,weight){
    this.name = name;
    this.weight = weight;
  }
function Cat(){
    Animal.call(this,'cat','50');
    //Animal.apply(this,['cat','50']);
    this.say = function(){
    console.log('i am '+this.name+'myweight'+this.weight)
    }

  }

var cat = new Cat();
cat.say();

这段代码自己理解一下。。。。

关于call 和 apply的更多相关文章

  1. JS核心系列:浅谈 call apply 与 bind

    在JavaScript 中,call.apply 和 bind 是 Function 对象自带的三个方法,这三个方法的主要作用是改变函数中的 this 指向,从而可以达到`接花移木`的效果.本文将对这 ...

  2. SQL Server-聚焦APPLY运算符(二十七)

    前言 其实有些新的特性在SQL Server早就已经出现过,但是若非系统的去学习数据库你会发现在实际项目中别人的SQL其实是比较复杂的,其实利用新的SQL Server语法会更加方便和简洁,从本节开始 ...

  3. 利用apply()或者rest参数来实现用数组传递函数参数

    关于call()和apply()的用法,MDN文档里写的非常清晰明白,在这里就不多做记录了. https://developer.mozilla.org/zh-CN/docs/Web/JavaScri ...

  4. 由js apply与call方法想到的js数据类型(原始类型和引用类型)

    原文地址:由js apply与call方法想到的js数据类型(原始类型和引用类型) js的call方法与apply方法的区别在于第二个参数的不同,他们都有2个参数,第一个为对象(即需要用对象a继承b, ...

  5. JavaScript学习笔记(二)——闭包、IIFE、apply、函数与对象

    一.闭包(Closure) 1.1.闭包相关的问题 请在页面中放10个div,每个div中放入字母a-j,当点击每一个div时显示索引号,如第1个div显示0,第10个显示9:方法:找到所有的div, ...

  6. 瞬间记住Javascript中apply与call的区别

    关于Javascript函数的apply与call方法的用法,网上的文章很多,我就不多话了.apply和call的作用很相似,但使用方式有区别 apply与call的第一个参数都是一个对象,这个对象就 ...

  7. scope.$apply是干嘛的

    开始用angular做项目的时候,一定碰到过$scope.$apply()方法,表面上看,这像是一个帮助你进行数据更新的方法,那么,它为何存在,我们又该如何使用它呢. JavaScript执行顺序 J ...

  8. JavaScript中的apply,call与this的纠缠

    1.apply定义 apply:调用函数,并用指定对象替换函数的 this 值,同时用指定数组替换函数的参数. 语法:apply([thisObj[,argArray]]) thisObj 可选.要用 ...

  9. jQuery之常用且重要方法梳理(siblings,nextAll,end,wrap,apply,call,each)-(二)

    1.siblings() siblings() 获得匹配集合中每个元素的同胞,通过选择器进行筛选是可选的. <body> <div><span>Hello</ ...

  10. JS中 call() 与apply 方法

    1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一个对象替换当前对象. 说明: call ...

随机推荐

  1. JLS(Third Edition) Chapter12 Execution

    这一章详细说明在一个program执行时,发生的activities. 它根据JVM和组成program的类.接口.实例的生命周期 组织.   一个JVM从加载一个特定的类并调用它的main方法开始启 ...

  2. 面试集锦-常量,const, const 对指针的影响

    在C语言中不可改变的数据(量)就是常量    在C语言中有三种常量        字面量(直接量),就是直接写出来的,从写法上就可以看出值与类型等,例如:19,123.456等        名字常量 ...

  3. 2013长沙 G Graph Reconstruction (Havel-Hakimi定理)

    Graph Reconstruction Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge Let there ...

  4. Redis优化之CPU充分利用

    Linux Redis Server之CPU充分利用 不知道大家有没有注意到你们公司的集群配置是否是有一种配置是这样的: 多个Redis Server分布在同一个节点,只是端口不同,如果有的话,应该是 ...

  5. Try-Catch机制使用场景分析

    (一)在什么场景下加Try-Catch机制   1)以业务逻辑功能为单位,在最上层加Try-Catch机制.为什么要这样做呢?这主要是增加程序的健壮性,防止因抛出异常过多,导致程序崩溃. try { ...

  6. JS清除IE浏览器缓存的方法

    js中自动清除ie缓存方法 — 常用 对于动态文件,比如 index.asp?id=... 或者 index.aspx?id=... 相信有经验的程序员都知道怎样禁止浏览器缓存数据了.但是对于静态文件 ...

  7. Java 7 Concurrency Cookbook 翻译 第一章 线程管理之六

    十一.处理线程组中的未控制异常 每种编程语言一个很重要的特性就是其所提供的用来处理程序中错误情况的机制.Java语言和其他的现代语言一样,是提供了异常机制来处理对象程序中的错误.Java提供了很多的类 ...

  8. 如何在IE8设置透明背景

    background:rgba(0,0,0,0.5);filter: progid:DXImageTransform.Microsoft.gradient(startcolorstr=#7F00000 ...

  9. HDU1102(最小生成树Kruskal)

    开学第三周.........真快尼 没有计划的生活真的会误入歧途anytime 表示不开心不开心不开心 每天都觉得自己的生活很忙 又觉得想做的事又没有完成 这学期本来计划重点好好学算法,打码码,臭臭美 ...

  10. OpenGL图元的颜色属性

    OpenGL支持两种颜色模式:一种是RGBA,一种是颜色索引模式. 1. RGBA颜色RGBA模式中,每一个像素会保存以下数据:R值(红色分量).G值(绿色分量).B值(蓝色分量)和A值(alpha分 ...