北京沣登科技发展公司

j***ascript函数传参数,js 函数传参

大家好,今天小编关注到一个比较意思的话题,就是关于javascript函数参数问题,于是小编就整理了2个相关介绍JavaScript函数传参数的解答,让我们一起看看吧。

  1. js中oost怎么传递参数?
  2. JavaScript中函数都是值传递吗?

js中oost怎么传递参数?

<!DOCTYPE html>

<html lang=&#34;en">

javascript函数传参数,js 函数传参div>
图片来源网络,侵删)

<head>

<meta charset="UTF-8">

<title>Title</title>

javascript函数传参数,js 函数传参
(图片来源网络,侵删)

</head>

<body>

<button id = "func1">func1</button>

javascript函数传参数,js 函数传参
(图片来源网络,侵删)

<button οnclick="fn('func2')">func2</button>

<script>

javaScript中函数都是值传递吗?

是的,JavaScript中函数都是值传递,哪怕是object类型的参数也是一样,不过此时这个值就变为该object的地址值了,这块儿容易造成误解,因此要格外注意!

下面我们具体看一下:

quote>function setperson(obj) {
// 现在obj 和 person 指向内存中的同一块地址1
obj.name = "人生之路慢慢长";
obj.fensi = 800;
// obj 指向了新对象所在的地址2,切断了和地址1的联系
obj = new Object();
obj.fensi = 100000;
}
var person = new Object();
setName(person);
console.log(person.name); // 人生之路慢慢长
console.log(person.fensi); // 800

从上面的例子我们可以看到,person已经被赋予"人生之路慢慢长"的名字,我们来分析下,当我们把 person 的地址值传递给 obj 之后,obj 和 person 都指向了内存中的同一块地址1,所以这里对 obj 进行添加删除属性操作,都是在地址1上操作的,那么name属性以及fensi属性就会被赋予到person上了(使用自己账号来举个栗子,(✪ω✪))。

后面又修改了一次obj的fensi属性,但是为何最后fensi不是100000还是800呢(我倒希望是100000啊,哈哈)?关键点就在于“obj=new Object()”对 obj 重新赋值这句上, 这时候会切断了 obj 和地址1之间的联系,所以对 obj 上的任何操作也不会反映到 person 对象上。如果函数的参数是按引用传递的话, person 也会跟着指向地址2 , 然而事实上 person 指向的还是地址1,最终fensi还是之前的800而不是100000啦。

这点儿很容易搞混,所以大家要格外注意,在实际使用中不断强化,填好这个坑。大家如果觉得不错欢迎点赞哦,或者还有什么想法可以评论,大家一起讨论学习

到此,以上就是小编对于j***ascript函数传参数的问题就介绍到这了,希望介绍关于j***ascript函数传参数的2点解答对大家有用。

[免责声明]本文来源于网络,不代表本站立场,如转载内容涉及版权等问题,请联系邮箱:83115484@qq.com,我们会予以删除相关文章,保证您的权利。 转载请注明出处:http://www.fengdengtech.com/post/16560.html

分享:
扫描分享到社交APP