JS函数参数的传递与同名参数实例分析


Posted in Javascript onMarch 16, 2020

本文实例讲述了JS函数参数的传递与同名参数。分享给大家供大家参考,具体如下:

函数参数的传递

函数参数如果是原始类型值,传递方式是值传递。这意味着,在函数体内修改参数值,不会影响函数外部。

var p = 2 
function f(p) {
 p = 3
}
f(p)
p // 2

上面代码中,变量p是一个原始类型的值,传入函数f的方式是值传递,因此在函数内部,p的值是原始值的拷贝,无论怎么修改,都不会影响到原始值。

但是,如果函数参数是复合类型,传入函数的方式是引用的传递,也就是说,传入函数的是一个地址,因此在函数内部修改参数,将会影响到原始值。

var obj = { p: 1 };

function f(o) {
 o.p = 2;
}
f(obj);

obj.p // 2

上面代码中,传入函数f的参数对象obj的地址。因此,在函数内部修改obj的属性p,会影响到原始值 。

注意,如果函数内部修改的,不是参数对象的某个属性,而是替换掉整个参数,这时不会影响到原始值 。

var obj = [1, 2, 3];

function f(o) {
 o = [2, 3, 4];
}
f(obj);

obj // [1, 2, 3]

上面代码中,在函数f内部,参数对象obj被整个替换成另一个值。这时不会影响到原始值。这是因为,形式参数(o)的值实际是参数obj的地址,重新对o赋值 ,导致o指向另一个地址,保存在原地址上的值当然不受影响。

函数中的同名参数

如果函数中出现了同名参数,则取最后出现的那个值

function f(a, a) {
 console.log(a);
}

f(1, 2) // 2

上面代码中,函数f有两个参数,且参数名都为a,取值 的时候,以后面的a为准,即使后面的a没有值,或者被省略,也是以其为准。

function f(a, a) {
 console.log(a);
}

f(1) // undefined

调用函数f的时候,没有提供第二个参数,a的取值就变成了undefined。这时,如果要获得第一个a的值,可以使用arguments对象。

function f(a, a) {
 console.log(arguments[0]);
}

f(1) // 1

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
TimergliderJS 一个基于jQuery的时间轴插件
Dec 07 Javascript
jQuery中die()方法用法实例
Jan 19 Javascript
JS解析XML文件和XML字符串详解
Apr 17 Javascript
JQuery中层次选择器用法实例详解
May 18 Javascript
jQuery中hover方法搭配css的hover选择器,实现选中元素突出显示方法
May 08 jQuery
基于Vue的延迟加载插件vue-view-lazy
May 21 Javascript
Rollup处理并打包JS文件项目实例代码
May 31 Javascript
layer弹出层 iframe层去掉滚动条的实例代码
Aug 17 Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
Jan 20 Javascript
JS实现小星星特效
Dec 24 Javascript
JS面试题中深拷贝的实现讲解
May 07 Javascript
使用Vue.js和MJML创建响应式电子邮件
Mar 23 Vue.js
vue css 引入asstes中的图片无法显示的四种解决方法
Mar 16 #Javascript
JS函数本身的作用域实例分析
Mar 16 #Javascript
JavaScript实现tab栏切换效果
Mar 16 #Javascript
vue-cli3使用mock数据的方法分析
Mar 16 #Javascript
vue-cli3.0实现一个多页面应用的历奇经历记录总结
Mar 16 #Javascript
vue从零实现一个消息通知组件的方法详解
Mar 16 #Javascript
JavaScript实现动态留言板
Mar 16 #Javascript
You might like
php解析url的三个示例
2014/01/20 PHP
PHP两种快速排序算法实例
2015/02/15 PHP
Python中使用django form表单验证的方法
2017/01/16 PHP
jQuery Ajax之$.get()方法和$.post()方法
2009/10/12 Javascript
Extjs TriggerField在弹出窗口显示不出问题的解决方法
2010/01/08 Javascript
深入理解JavaScript系列(50):Function模式(下篇)
2015/03/04 Javascript
js实现的牛顿摆效果
2015/03/31 Javascript
纯JavaScript代码实现移动设备绘图解锁
2015/10/16 Javascript
分享几种比较简单实用的JavaScript tabel切换
2015/12/31 Javascript
解析javascript瀑布流原理实现图片滚动加载
2016/03/10 Javascript
jQuery技巧之让任何组件都支持类似DOM的事件管理
2016/04/05 Javascript
实现JavaScript的组成----BOM和DOM详解
2016/05/18 Javascript
Web开发中客户端的跳转与服务器端的跳转的区别
2017/03/05 Javascript
vue 如何添加全局函数或全局变量以及单页面的title设置总结
2017/06/01 Javascript
简单谈谈axios中的get,post方法
2017/06/25 Javascript
nodejs 子进程正确的打开方式
2017/07/03 NodeJs
vue的安装及element组件的安装方法
2018/03/09 Javascript
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
vue实现带复选框的树形菜单
2019/05/27 Javascript
js实现九宫格抽奖
2020/03/19 Javascript
vue结合el-upload实现腾讯云视频上传功能
2020/07/01 Javascript
详解Howler.js Web音频播放终极解决方案
2020/08/23 Javascript
小程序自定义圆形进度条
2020/11/17 Javascript
python判断给定的字符串是否是有效日期的方法
2015/05/13 Python
python的re正则表达式实例代码
2018/01/24 Python
pip install python 快速安装模块的教程图解
2019/10/08 Python
在python中求分布函数相关的包实例
2020/04/15 Python
python中sklearn的pipeline模块实例详解
2020/05/21 Python
python有几个版本
2020/06/17 Python
python3:excel操作之读取数据并返回字典 + 写入的案例
2020/09/01 Python
详解CSS3媒体查询响应式布局bootstrap 框架原理实战(推荐)
2020/11/16 HTML / CSS
党委书记个人对照检查材料
2014/09/15 职场文书
安全月宣传标语
2014/10/07 职场文书
先进教育工作者事迹材料
2014/12/23 职场文书
狮子林导游词
2015/02/03 职场文书
golang使用map实现去除重复数组
2022/04/14 Golang