代码信息来自于http://ejohn.org/apps/learn/。

使用数量可变的参数对编程很有好处

function merge(root){
for(i = 0 ; i < arguments.length; i++)
for(var key in arguments[i])
return root[key] = arguments[i][key]
} var merged = merge({name: "John"}, {city: "Boston"});
console.log( merged.name == "John", "name属性和原来一样." );
console.log( merged.city == "Boston", "city属性被复制到了第一个参数对象里" );

采用这个方法可以设置数量位置不固定的参数,它的思路就是用访问二维数组的方法访问所有对象,将所有的内容复制到第一个对象。

这里要注意,传进来的所有参数存在于arguments对象中,而函数的形参,依次对应传进来的参数。像本题,arguments包括{name: "John"},{city: "Boston"};而root是{name: "John"}。

如何构建找到数组当中最大/最小数字的函数?

function smallest(array){
return Math.min.apply( Math, array );
}
function largest(array){
return Math.max.apply( Math, array );
}
console.log(smallest([0, 1, 2, 3]) == 0, "找到最小值的位置");
console.log(largest([0, 1, 2, 3]) == 3, "找到最大值的位置");

另一种方法

function smallest(){
return Math.min.apply( Math, arguments );
}
function largest(){
return Math.max.apply( Math, arguments );
}
console.log(smallest(0, 1, 2, 3) == 0, "找到最小值的位置");
console.log(largest(0, 1, 2, 3) == 3, "找到最大值的位置");

这段代码哪里出的错?

function highest(){
return arguments.sort(function(a,b){
return b - a;
});
}
console.log(highest(1, 1, 2, 3)[0] == 3, "获取最高值");
console.log(highest(3, 1, 2, 3, 4, 5)[1] == 4, "查看数组第二个元素");

sort是数组对象的方法。

习题:有没有什么内置方法可以帮助来转化类数组对象为数组对象?

// 提示: 数组拥有返回新数组的.slice和.splice方法.
function highest(){
return makeArray(arguments).sort(function(a,b){
return b - a;
});
} function makeArray(array){
// 补足代码
} // 期望: [3,2,1,1]
console.log(highest(1, 1, 2, 3)[0] == 3, "获取最大值");
// 期望: [5,4,3,3,2,1]
console.log(highest(3, 1, 2, 3, 4, 5)[1] == 4, "验证结果");

我们可以使用好用的内置方法

function highest(){
return makeArray(arguments).sort(function(a,b){
return b - a;
});
}
function makeArray(array){
return Array().slice.call(array);
} console.log(highest(1, 1, 2, 3)[0] == 3, "获取最大值");
console.log(highest(3, 1, 2, 3, 4, 5)[1] == 4, "验证结果");

这里是类数组和数组的转化方法,通过call,修改上下文,调用slice实现。

习题:实现一个乘法函数(第一个参数,和剩余参数的最大值)

function multiMax(multi){
// 获取一个没有第一个参数的数组
var allButFirst = ___; // 在剩余的参数数组中找到最大的数字
var largestAllButFirst = ___; return multi * largestAllButFirst;
}
console.log( multiMax(3, 1, 2, 3) == 9, "3*3=9 (第一个参数, 剩余参数的最大值)" );

使用call和apply可以很好解决这个问题

function multiMax(multi){
// 获取一个没有第一个参数的数组
var allButFirst = Array().slice.call(arguments,1);
// 在剩余的参数数组中找到最大的数字
var largestAllButFirst = Math.max.apply(Math,allButFirst); return multi * largestAllButFirst;
}
console.log( multiMax(3, 1, 2, 3) == 9, "3*3=9 (第一个参数, 剩余参数的最大值)" );

javascript高级知识分析——灵活的参数的更多相关文章

  1. javascript高级知识分析——上下文

    如果函数是一个对象的属性,那么它可以? var katana = { isSharp: true, use: function(){ this.isSharp = !this.isSharp; } } ...

  2. javascript高级知识分析——实例化

    代码信息来自于http://ejohn.org/apps/learn/. new做了什么? function Ninja(){ this.name = "Ninja"; } var ...

  3. javascript高级知识分析——作为对象的函数

    代码信息来自于http://ejohn.org/apps/learn/. 函数和对象是不是非常相似? var obj = {}; var fn = function(){}; console.log( ...

  4. javascript高级知识分析——函数访问

    代码信息来自于http://ejohn.org/apps/learn/. 可以通过函数的名字在它的内部引用它. function yell(n){ return n > 0 ? yell(n-1 ...

  5. javascript高级知识分析——定义函数

    代码信息来自于http://ejohn.org/apps/learn/. 可以使用哪些方式来声明函数? function isNimble(){ return true; } var canFly = ...

  6. JavaScript的高级知识---词法分析

    JavaScript的高级知识---词法分析 词法分析 词法分析方法: js运行前有一个类似编译的过程即词法分析,词法分析主要有三个步骤: 分析参数 再分析变量的声明 分析函数说明 函数在运行的瞬间, ...

  7. (读书笔记)函数参数浅析-JavaScript高级程序设计(第3版)

    ECMAScript函数不介意传递的参数个数,因为在其内部是用一个数组进行表示的.在函数体内可以通过arguments对象来访问这个参数数组,就像我们正常访问数组一样处理. arguments对象只是 ...

  8. MySQL高级知识(七)——索引面试题分析

    前言:该篇随笔通过一些案例,对索引相关的面试题进行分析. 0.准备 #1.创建test表(测试表). drop table if exists test; create table test( id ...

  9. MySQL高级知识(五)——索引分析

    前言:前面已经学习了explain(执行计划)的相关知识,这里利用explain对索引进行优化分析. 0.准备 首先创建三张表:tb_emp(职工表).tb_dept(部门表)和tb_desc(描述表 ...

随机推荐

  1. 【HDU 5532 Almost Sorted Array】水题,模拟

    给出一个序列(长度>=2),问去掉一个元素后是否能成为单调不降序列或单调不增序列. 对任一序列,先假设其可改造为单调不降序列,若成立则输出YES,不成立再假设其可改造为单调不增序列,若成立则输出 ...

  2. json概述及python处理json等数据类型

    <一,概念> 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON.XML等.反序列化(deserialization): ...

  3. .NET委托:一个关于C#的睡前故事 【转】

    紧耦合 从前,在南方一块奇异的土地上,有个工人名叫彼得,他非常勤奋,对他的老板总是百依百顺.但是他的老板是个吝啬的人,从不信任别人,坚决要求随时知道彼得的工作进度,以防止他偷懒.但是彼得又不想让老板呆 ...

  4. 什么是OAuth

    什么是OAuth 如今很多网站的功能都强调彼此间的交互,因此我们需要一种简单,标准的解决方案来安全的完成应用的授权,于是,OAuth应运而生,看看官网对其的定义: An open protocol t ...

  5. HDU 3081Marriage Match II(二分法+并检查集合+网络流量的最大流量)

    职务地址:http://acm.hdu.edu.cn/showproblem.php? pid=3081 有一段时间没写最大流的题了,这题建图竟然想了好长时间... 刚開始是按着终于的最大流即是做多轮 ...

  6. C#整理6——数组的应用

    数组的应用:(一).冒泡排序.1.冒泡排序是用双层循环解决.外层循环的是趟数,里层循环的是次数.2.趟数=n-1:次数=n-趟数.3.里层循环使用if比较相临的两个数的大小,进行数值交换. 作业:1. ...

  7. Android Service 系统服务

    android sdk 提供很多公用的服务,也就是系统服务,开发者可以通过Activity类的getSystemService方法获取指定的服务.系统服务包含音频服务.视频服务窗口服务等.本篇主要讲T ...

  8. 5.7.13mysql 无法登陆

    话不多说 用的http://dev.mysql.com/downloads/mysql/下的ZIP  Archive安装方式 下载 解压,然后吧bin目录添加到系统path环境变量下.然后将my-de ...

  9. getgrgid()函数

    getgrgid(从组文件中取得指定gid 的数据)相关函数 fgetgrent,getgrent,getgrnam表头文件 #include<grp.h>#include<sys/ ...

  10. nginx 学习笔记【持续更新...】

    1.如果在安装过程中出现以下错误 需要安装pcre库 解决方案:yum install pcre 2.如果nginx启动提示端口被占用,则停止该端口的服务再启动nginx,一般为httpd服务 解决方 ...