一、数组去重,直接写到Array原型链上。

 //该方法只能去除相同的数字   不会去判断24和'24'是不同的   所有数字和字符串数字是相同是重复的
Array.prototype.redup=function(){
var obj={};
for(var i=0;i<this.length;i++){
var val=this[i];
if(obj[val]==this[i]){ //如果发现重复的
this[i]=this[this.length-1]; //那就把最后一个赋值给当前的这个数组元素
this.pop(); //并把最后一个元素删除
i--; //数组长度减少 那么i也要减下 下次循环重复判断该i位置的值是否重复
}
obj[val]=val;
}
obj=null; //释放掉null
return this; //返回这个去重的数组
} arr=[24,25,24,26,24,25,23,24,25,26];
console.log(arr.redup());//[24,25,26,23];

二、call    apply    bind  之间的区别

 //call、apply、bind都是改变函数的中this上下文的
//call、apply非常的相似,唯一的区别的就是call是单个传参,除第一个参数是改变this指向 其他参数根据函数的参数来定
//而apply一共就两个参数,第一个参数改变this指向,第二个参数是数组 ,是函数参数的集合。
//call,apply不但会改变this指向 并且会执行函数
//但bind和上面有点区别,同样第一个参数是改变this指向,后面的参数也是传给函数的参数 但bind并不执行函数
function sum(a,b){
this.sum=a+b;
console.log(this.sum);
}
function fn(){
}
sum.call(fn,1,2); //3 把this指向fn 所以fn有sum属性了 并且执行sum函数
console.log(fn.sum); //
sum.apply(fn,[2,3]); //5 把this指向fn 所以fn有sum属性了 并且执行sum函数
console.log(fn.sum); //
sum.bind(fn,3,4); //bind并不执行函数 所以 这里什么都不打印
console.log(fn.sum); //5 //bind当中只是改变了this指向 并没有执行 也没有出现赋值步骤 所以 fn.sum保持以前的值
sum.bind(fn,3,4)(); //7 //执行函数 改变fn.sum属性的值 并打印
console.log(fn.sum); // //这里还有一点需要值得注意的 在非严格模式下 不管call,bind,apply没有明确指向谁 默认就是window
sum.call();// this 指向window
sum.call(null);// this 指向window
sum.call(undefined);// this 指向window
//而在严格模式下
sum.call();// this 指向undefined
sum.call(null);// this 指向null
sum.call(undefined);// this 指向undefined

this用法总结

第一句话:this是谁和函数的在哪执行的以及在哪定义的都木有半毛钱关系

this是谁分几种情况:

第一种:函数谁调用this就指向谁,主要看函数(方法)前面的 . 是谁   那么this就是谁   没有 . 那就是window咯

第二种:在构造函数中  this  指的是当前构造函数中的实例    (当然  方法中的this不算   那么方法的this是谁?  看第一种情况);

第三种:就是call,apply,bind   那就直接看上面吧   第一个参数是谁   那么this就是谁    没有参数呢?上面讲的很清楚了

第四种:函数自执行   像这样(function(){})()      好吧   在非严格模式下     this指的就是window    而在严格模式下    this 是undefined;  所以,严格模式要写上执行主体哈。

数组去重,call、apply、bind之间的区别,this用法总结的更多相关文章

  1. GROUP BY,WHERE,HAVING之间的区别和用法

      GROUP BY,WHERE,HAVING之间的区别和用法 分类: Oracle学习2009-11-01 23:40 21963人阅读 评论(6) 收藏 举报 mathmanagersql数据库m ...

  2. 浅谈C++中指针和引用的区别者之间的区别和用法(转)

    指针和引用在C++中很常用,但是对于它们之间的区别很多初学者都不是太熟悉,下面来谈谈他们2者之间的区别和用法. 1.指针和引用的定义和性质区别: (1)指针:指针是一个变量,只不过这个变量存储的是一个 ...

  3. javascript中的call(),apply(),bind()方法的区别

    之前一直迷惑,记不住call(),apply(),bind()的区别.不知道如何使用,一直处于懵懂的状态.直到有一天面试被问到了这三个方法的区别,所以觉得很有必要总结一下. 如果有不全面的地方,后续再 ...

  4. JavaScript中call,apply,bind方法的区别

    call,apply,bind方法一般用来指定this的环境. var a = { user:"hahaha", fn:function(){ console.log(this.u ...

  5. 简述this,call,apply,bind之间的关系

    一.什么是this? this是JavaScript语言的一个关键字,它是函数运行时在函数体内部自动生成的一个对象,只能在函数体内部使用.函数的不同使用场合,this的指向不同. 在ES5中,this ...

  6. JS中apply和call的区别和用法

    Javascript中有一个call和apply方法,其作用基本相同,但是它们也有略微不同的地方. JS手册中对call方法的解释是: call方法:调用一个对象的一个方法,以另一个对象替换当前对象. ...

  7. COOKIE和SESSION之间的区别以及用法

    一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...

  8. 【debug、info、warn、error】四者之间的区别与用法

    debug:需要在调试过程中输出的信息,但发布后是不需要的(当然发布后,也是看不到的) info:需要持续输出的信息(无论调试还是发布状态) warn:警告级别的信息(不严重) error:错误信息( ...

  9. css中字体单位px,pt,em,百分比之间的区别和用法

    px 即像素,一般国内网站使用较多,默认大小是16px; pt 印刷行业常用单位 em  相对单位,相对父元素属性的单位 ,一般用于移动端布局 rem  结合相对定位和绝对定位的优势,相对根元素htm ...

随机推荐

  1. 老李推荐:第14章3节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-HierarchyViewer实例化

    老李推荐:第14章3节<MonkeyRunner源码剖析> HierarchyViewer实现原理-HierarchyViewer实例化 poptest是国内唯一一家培养测试开发工程师的培 ...

  2. Windows下Nginx的安装与使用(一):配置端口转发

    什么是端口转发 当我们在服务器上搭建一个图书以及一个电影的应用,其中图书应用启动了 8001 端口,电影应用启动了 8002 端口.此时如果我们可以通过: localhost:8001 //图书 lo ...

  3. sublime Text3快捷键使用大全

    Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本.Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑.举个栗子:快速选中并更改所有相同的变量名.函数名等.Ct ...

  4. Android 学习笔记之 个人认为最简单的查看Android源码方案

    相信很多人都会疑惑如何使用Eclipse ADT查看源码? 下面我们将介绍 如何查看Android源码. 本文有如下优点: 1.不用费心去找Android源码地址:一个字烦,网上的东西杂七杂八的... ...

  5. SDWebImage 加载显示 GIF 与性能问题

    SDWebImage 加载显示 GIF 与性能问题 SDWebImage 4.0 之前,可以用 UIImageView 显示 GIF 图.如果 SDWebImage 4.0 还这么做,只会显示静态图. ...

  6. day001-html知识点总结(-)块级。行内元素区分

    -.行内元素和块级元素的区别与转换: 区别: 1.从形式上看,在标准文档流中,行内元素会水平方向呈线性排列,而块级元素会各占一行,垂着方向排列. 2.在结构使用上,块级元素可以包含行内元素和块级元素, ...

  7. Node.js 原理简介

    Node.js 的官方文档中有一段对 Node.js 的简介,如下. Node.js® is a JavaScript runtime built on Chrome's V8 JavaScript ...

  8. Ajax 与 Comet

    Ajax技术的核心是XMLHttpRequest对象(简称XHR). XMLHttpRequest对象 在浏览器中创建XHR对象要像下面这样,使用XMLHttpRequest构造函数. var xhr ...

  9. Linux配置mysql (centos配置java环境 mysql配置篇 总结四)

    ♣安装的几种方法和比较 ♣配置yum源 ♣安装mysql ♣启动mysql ♣修改密码 ♣导入.sql文件 ♣缓存设置 ♣允许远程登录(navicat) ♣配置编码为utf8  1.关于Linux系统 ...

  10. windows下批量换程序——运维常用

    Windows一批机器,需要批量换程序.写个脚本给大家. net stop sharedaccess (关闭防火墙) del /s d:\*.log d:\*.vbs d:\*.pdb d:\*.vb ...