var arr=[1,2,3,4,5]; arr.length=3; console.log(arr)//[1,2,3]
直接改变数组的length的值数组
var arr = [1,1,2,2,3,3] const removeDuplicateltems = arr => [...new Set(arr)]; console.log(removeDuplicateltems(arr))//[1,2,3] /** * ...拓展运算符,是遍历Symbol.iterator * 和for...of同样的遍历方法 */
//把函数做为值传入进去 function callSomeFunction(someFunction,someArgument){ return someFunction(someArgument); }
最终调用的这个函数 他有两个参数, 第一个参数是一个方法 , 第二个参数是第一个方法的参数。浏览器
function add10(num){ return num + 10; } var result1=callSomeFunction(add10,10); console.log(result1);//20
这个例子稍微一看就明白了吧, 传入的10 最终成了add()的参数, 也就是成了num, 因此结果是20函数
function getGreeting(name){ return "holle," + name; } var result2=callSomeFunction(getGreeting, "Nicholas"); console.log(result2);//holle Nicholas
上面的理解了 这个也就不难了 同理 “ Nicholas” 变成了getGreeting() 的参数 name,因此输出结果是 holle Nicholasthis
先看看关于call()的官方解释,“调用一个对象的一个方法,以另外一个对象替换当前对象。”,看了这样的解释,或许让你更摸不着头脑了。看例子:指针
var x = "我是全局变量"; //定义全局变量x function a(){ //定义函数类结构a this.x = "我是在函数类结构a中声明的哦"; } //定义普通函数,弹出当前指针所包含的变量x的值 function f(){ alert (this.x); } f.call(new a());//返回值为“我是在函数类结构a中声明的哦”
个人理解是,f.call(new a())就是把函数(其实也是对象)f复制到被调用对象“new a()”下面去解析,事实上和下面这段代码的解析结果同样:code
function a(){ this.x = "我是在函数类结构a中声明的哦"; alert(this.x); //我是在函数类结构a中声明的哦 } a();
只不过此时变量X的做用域不一样而已,咿…看起来好像有点继承的味道哦,难道不是吗?在上例中,f彻底被构造函数a的实力对象继承了,若是说这还不足以说明a.call(b)是一种继承模式,那么再看一个更具备继承味道的用法吧。对象
function f(){ this.a ="a"; this.b = function(){ alert("b"); } } function e(){ f.call(this); } var c = new e(); alert(c.a); //弹出a c.b(); //弹出b
在这个例子中,只要会使用浏览器的朋友,都能看得出来e彻底继承了f的属性和方法,不然是没法解释的,由于在e中并无定义属性a和b,那么按常理推断在e的实例对象c中,并不会出现这两个属性。继承