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 相关文章推荐
JavaScript 的方法重载效果
Aug 07 Javascript
node.js WEB开发中图片验证码的实现方法
Jun 03 Javascript
Node.js开源应用框架HapiJS介绍
Jan 14 Javascript
jquery实现翻动fadeIn显示的方法
Mar 05 Javascript
SpringMVC restful 注解之@RequestBody进行json与object转换
Dec 10 Javascript
Node.js DES加密的简单实现
Jul 07 Javascript
jQuery:unbind方法的使用详解
Aug 14 jQuery
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
Oct 10 Javascript
webpack 4.0.0-beta.0版本新特性介绍
Feb 10 Javascript
Vue-Router模式和钩子的用法
Feb 28 Javascript
小程序如何在不同设备上自适应生成海报的实现方法
Aug 20 Javascript
layui将table转化表单显示的方法(即table.render转为表单展示)
Sep 24 Javascript
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
制作个性化的WordPress登陆界面的实例教程
2016/05/21 PHP
11款基于Javascript的文件管理器
2009/10/25 Javascript
JQuery 学习笔记01 JQuery初接触
2010/05/06 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
2010/09/28 Javascript
jquery获取下拉列表的值为null的解决方法
2011/03/18 Javascript
jQuery随便控制任意div隐藏的方法
2013/06/28 Javascript
JS 实现导航栏悬停效果
2013/09/23 Javascript
JavaScript数据结构与算法之栈详解
2015/03/12 Javascript
JQuery实现鼠标移动图片显示描述层的方法
2015/06/25 Javascript
js添加事件的通用方法推荐
2016/05/15 Javascript
jQuery的Read()方法代替原生JS详解
2016/11/08 Javascript
jQuery选取所有复选框被选中的值并用Ajax异步提交数据的实例
2017/08/04 jQuery
Vue.js表单标签中的单选按钮、复选按钮和下拉列表的取值问题
2017/11/22 Javascript
详解webpack+express多页站点开发
2017/12/22 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
2018/12/03 Javascript
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
JS localStorage存储对象,sessionStorage存储数组对象操作示例
2020/02/15 Javascript
Python3 适合初学者学习的银行账户登录系统实例
2017/08/08 Python
python实现Dijkstra算法的最短路径问题
2019/06/21 Python
Python 列表去重去除空字符的例子
2019/07/20 Python
Python实现微信翻译机器人的方法
2019/08/13 Python
Python celery原理及运行流程解析
2020/06/13 Python
python中的插入排序的简单用法
2021/01/19 Python
Lookfantastic美国/加拿大:英国知名美妆购物网站
2019/03/27 全球购物
Parfumdreams芬兰:购买香水和化妆品
2021/02/13 全球购物
外贸实习生自荐信范文
2013/11/24 职场文书
六查六看自查材料
2014/02/17 职场文书
父母对孩子的寄语
2014/04/09 职场文书
数学兴趣小组活动总结
2014/07/08 职场文书
建筑安全责任书范本
2014/07/24 职场文书
单位活动策划方案
2014/08/17 职场文书
财务稽核岗位职责
2015/04/13 职场文书
php 防护xss,PHP的防御XSS注入的终极解决方案
2021/04/01 PHP
深入详解JS函数的柯里化
2021/06/09 Javascript
MySQL系列之二 多实例配置
2021/07/02 MySQL
什么是Python装饰器?如何定义和使用?
2022/04/11 Python