call的其他应用
看一些源码的时候常常发现例如这些的代码
Array.prototype.slice.call(arg)
Object.prototype.toString.call(str)
等等 ,着一些系列的句子,当时的我内心是这样的
问题总是要解决的,各种百度 有木有
最后在网上看到一个大牛的博客,他这样写到
var fun=function () {
console.log(this); //String {0: "m", 1: "e", 2: "n", 3: "g", length: 4, [[PrimitiveValue]]: "meng"}
console.log(this instanceof String); //true
};
fun.call("meng");
这段代码执行方式不难看出,就是this指向了字符串"meng"。
注意这里,我并没有说把"meng"传入到到了方法fun中
在看如下代码
var fun=function (value) {
console.log(value); //undefined
};
fun.call("meng");
返回的结果是undefined,也就是说,只是指向了,并没有“处理”参数,其实想想call的用法,它也该如此。。
好了,基础演戏看完了,各位看官想必也明白了,最后再看下代码的执行效果吧
var obj = {length: 2, 0: "first", 1: "two"};
var result = Array.prototype.slice.call(obj);
console.log(result); //["first", "two"]
result = Object.prototype.toString.call(obj);
console.log(result); //[object Object]
当然也可这样写Array.prototype.slice.call(arg,n)表示从第n项开始截取
这里在补充网上的一种说法:
slice()方法没有参数的话,会从0开始剪切到最后。
所以上面的代码可以这样理解,代码从0剪切到1,结果生成数组,对应的结果就如上了。。
其实这样说的前提是,你得理解slice内部的方法实现。
最最最终奥义:Object.protype.Fun.call(n,m)这种结构,
对n执行Fun(m)。
m不存在,执行Fun默认方法。
思维扩展下,Array.prototype.slice.call(arg)其实可以这样用(临时想到的,感觉可以)
如网上一些数据的解析方式是这样的
用的0,1,2....等数字做的属性名(前两天从php后天获取的数据也是如此),今天学到这个方法后是不是可以这样处理一下
var con1=document.querySelector(".con1");
var result=window.getComputedStyle(con1);
console.log(Array.prototype.slice.call(result[3]).join(""));
当然你也可以这样处理
var con1=document.querySelector(".con1");
var result=window.getComputedStyle(con1);
console.log(result[3]);
返回的结果是一样的
上面的哪一种看着显然麻烦,这里提到主要有两点原因
1,深刻理解下.call()方法
2,为解决问题多一种思路
刚刚又从网上看到了个它的用处
js arguments类型像数组但不是数组,所以也就有了,把arguments转换成数组的方法(插件用它的意义也在于此)
随机推荐
- Spring源码之SimpleAliasRegistry解读(一)
Spring源码之SimpleAliasRegistry解读(一) 阅读spring源码中org.springframework.core.SimpleAliasRegistry类时发现该类主要是使用 ...
- C++vector迭代器失效的问题
转载:http://blog.csdn.net/olanmomo/article/details/38420907 转载:http://blog.csdn.net/stpeace/article/de ...
- uTenux——软件底层驱动组织结构介绍
经过第一节对uTenux初步认识和第二节对uTenux\AT91SAM3S4C开发板的硬件结构的介绍,这一节我们将要学习的是uTenux\AT91SAM3S4C的软件底层驱动. 在悠龙公司的官网或者u ...
- BZOJ 3159决战
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3159 题意:给出一棵树,(1)路径加一个值:(2)路径上的节点的值反转(只是值反转,不是节 ...
- iOS日常工作之常用宏定义大全
前言: 在工作中, 很多小伙伴都会在PCH文件定义一些常用的宏,但是又怕写这些简单的宏浪费时间,又有时候忘记怎么定义了怎么办?本人在工作中也是如此.所以在这里给大家分享一些常用的宏定义,喜欢的小伙伴可 ...
- Oracle中创建用户和授权
默认的:最高权限用户:SYSTEM 密码:MANAGER 管理员权限用户:SYS 密码:CHANGE_ON_INSTALL 普通用户:SCOTT 密码:TIGER 登 陆管理员或超级管理员用户可以自己 ...
- GCC编译器代码优化
代码优化是指编译器通过分析源代码,找出其中尚未达到最优的部分,然后对其重新进行组合,目的是改善程序的执行性能.GCC提供的代码优化功能非常强大,它通过编译选项-On来控制优化代码的生成,其中n是一个代 ...
- error: command 'gcc' failed with exit status 1 的解决办法
yum install gcc python-devel 之前yum install gcc* 了 所以没成功. wget http://prdownloads.sourceforge.net/doc ...
- sql默认启动密码
首先启动sqlplus输入用户名:sqlplus / as sysdba密码空缺如果用户被锁定,记得加上SQL> alter user dbsnmp account unlock; User a ...
- SQL语句最基本的性能优化方法
有些人还不知道sql语句的基本性能优化方法,在此我简单提醒一下,最基本的优化方法: 1.检查是否缺少索引.调试的时候开启“包括实际的执行计划” 执行后会显示缺少的索引, 然后让dba帮助添 ...