在创建一个函数并调用时可以传入一些参数或变量,不过函数究竟可以有多少可用的参数呢?
以下通过一个例子来检查在调用函数时会有哪些变量和参数,在这里可以在浏览器的“无痕窗口”中直接运行这段代码(无痕窗口能避免浏览器插件影响运行)。
注意:这里仅仅针对传统函数,箭头函数的运行变量与传统函数不同,在此不做讨论。
var globalVariable = '全局变量';
var obj = {
aFunction: function (para) {
var localVariables = '局部变量';
console.log(para, localVariables, arguments, this, globalVariable);
// 包含传入的参数
}
}
obj.aFunction('我是一段描述', 2, 3);
在运行时切换到 Source 页,并用 Chrome 的 JavaScript 调试模式来进行验证。
接下来进入到 aFunction 的函数中时,可以切换到 console.log(...) 一这行停下来,结果如下:
接下来会看到 Scope 表示当前函数的作用域,作用域中可调用的变量也会按顺序列出,在这里可以看到的变量和参数包含:
以上五个变量中,前两个就属于在调用时传入的变量,本文也会着重介绍它们的特点。
参数是由主调函数传入的变量,相对于其它编程语言来说, JS 传递参数的限制更少,任何值都可以作为参数,也正是因为如此,初次接触或从其它语言转过来的会有许多不熟悉的地方,以下是一些常见的问题:
这是一个非常基础的问题,刚开始学编程的新手经常会把参数名搞混,误以为调用时传入的参数名就是在函数内使用的名称,比如下面的例子输出的值是什么?
A. 'a', 'b', 'c', undefined
B. 'd', 'c', 'b', 'a'
function callMore(d, c, b, a) {
console.log(d, c, b, a);
}
var a = 'a';
var b = 'b';
var c = 'c';
callMore(a, b, c);
函数参数的名称是在定义函数时就已经确定了的,如下图:参数取值是按顺序带入,并且不会受到调用时名称的影响。
简单的结论:
如果已经定义了参数,但却没有传入,那么函数内取到的值为 undefined ,如果遇到这样的情况,代码就必须加入许多的容错机制,以避免 undefined 造的错误。
ES6 中新增了“参数默认值”可预先给特定参数设置默认值,除了避免 undefined 所造成的错误外,还可以增加使用函数的弹性。
下面的例子通过简单的语法就可加上“参数默认值”,当外部没有传入值时就会使用默认值。
function getMoney(money = 1000) {
console.log(`我有 ${ money }`);
}
getMoney(); // 不需要传入参数
如果无法确认所传入参数的数量该怎么办?
这种情况在项目开发中比较少见,但在开发框架、函数库时却很常见,前面所提到的 “如果未定义,但有更多的参数传入则需要使用其它方式取值”的情况 ,就会用到下面将要介绍的 arguments 参数(ES6 中有更好的方法)。
function callMore(d, c, b, a) {
// 注意:在此并没有用到定义的 d, c, b, a 参数
console.log(arguments);
}
var a = 'a';
var b = 'b';
var c = 'c';
callMore(a, b, c);
所有的传统函数都有 arguments 参数(注意:箭头函数没有),不需要另外定义即可直接调用,且作用域仅限于本函数中。
arguments 的结构本质上是一个数组,其中会包含调用时传入的所有值,在不确定传入参数的数量时,是一个很好用的方法。
因为 arguments 有一些缺点,如:
所以 ES6 新增了剩余参数语法,可在定义参数时直接传入剩余的未定的参数,语法如下:
const callMore = (a, ...args) => {
console.log(args);
}
var a = 'a';
var b = 'b';
var c = 'c';
callMore(a, b, c);
结果和前面的例子类似,但会是纯数组的方式展现,并且只会获取未定义的参数内容(a 会被跳过)。另外,箭头函数是可以使用剩余参数的。
函数除了可以传入纯值、数组和对象外,还可以把函数作为参数,使函数运行时更加丰富而且——呃。。。复杂。
下面的例子中,在调用 functionB 时,还可以传入另一个函数作为参数,这种手段叫回调函数( callback function)。
function functionB(fn) {
fn('小明');
}
functionB(function(name) {
console.log(name + ' 您好');
});
你自己可以试着看看其中的参数是如何传递的
JavaScript 可将函数作为参数传递这样的特性也称为“一级函数”(First-class Function)
在前端开发中,经常会遇到获取URL的相关数据,下面将总结下使用JavaScript来获取url地址的协议,参数,端口号,锚点等方法。
ECMAscript中所有函数的参数都是按值传递,也就是,把函数外部的值复制给函数内部的参数,就和把值从一个变量复制到另一个变量一样。js始终是按值传递,在这里称他为共享传递。
URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串。URLSearchParams()是个构造函数,将返回一个可以操作查询字符串的对象。
通过访问arguments对象的length属性可以获取有多少个参数传递给了函数。在封装函数的时候,会携带不同的参数,我们想要获取指定的参数,可以通过 arguments[ ] 来拿到,arguments对象可以与命名参数一起使用。arguments的值要永远与对应命名参数的值保持同步
给外部引用的js文件传递参数的4种方式:定义全局变量、在src后面传参、检索js文件(js文件要最后引入)、设置其他属性
一般error函数返回的参数有三个: function(jqXHR jqXHR, String textStatus, String errorThrown)。常见调用代码如下:这里对这三个参数做详细说明。
在日常工作中,我们需要将匹配到的所有路由,映射到一个组件上。如下代码想要达到的效果:不传page和id,则映射到user默认list页面,传page和id,根据page不同,显示不同的页面
函数是一段结合在一起执行特定任务的代码,函数一般使用参数与外部进行交互。要编写简洁高效的JS代码,必须掌握函数参数。在本文中,会使用一些有趣的例子来解释 JS 必须有效地处理函数参数的所有特性。
前后端传参一般有两种形式:key=value 形式传参(即 parameter 形式);body 形式传参(传 json 数据给后端),如果使用的是 GET 请求,浏览器展示的 Request URL 会自动在路径后面加上 ?a=1&b=2这样的参数,这就是 key=value 形式传参
* 参数可以使用逗号或分号分隔。 (建议使用分号,因为逗号具有双重含义:可以将其解释为mixin参数分隔符或者是css列表分隔符);使用逗号作为mixin分隔符使不可能创建逗号分隔的列表作为参数。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!