文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript传参的方式有哪些

2023-07-05 17:10

关注

这篇文章主要介绍“JavaScript传参的方式有哪些”,在日常操作中,相信很多人在JavaScript传参的方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript传参的方式有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1. 传递基本类型参数

在JavaScript中,基本类型参数(比如字符串、数字、布尔值等)是通过值传递的。这意味着,当我们将一个基本类型的值传递给一个函数时,函数会获得这个值的一个副本,而不是这个值本身。

下面是一个示例:

function updateName(name) {  name = "John";}let myName = "Jane";updateName(myName);console.log(myName); // 输出 "Jane"

在这个示例中,我们定义了一个函数updateName,它接受一个参数name。当我们将myName作为参数传递给这个函数时,函数会创建一个名字为name的变量的副本,并将其设置为"John"。然而,这并不会影响到myName变量的值,因为它仍然是"Jane"。这种意义上来说,这种现象也叫做浅拷贝。

2. 传递对象类型参数

当我们传递一个对象作为参数时,JavaScript会将这个对象的引用传递给函数。这意味着,当我们在函数中修改这个对象时,会影响到原始对象的值。

下面是一个示例:

function updatePerson(person) {  person.name = "John";}let myPerson = { name: "Jane" };updatePerson(myPerson);console.log(myPerson.name); // 输出 "John"

在这个示例中,我们定义了一个函数updatePerson,它接受一个参数person。当我们将myPerson作为参数传递给这个函数时,函数会获得myPerson对象的引用。因此,当我们在函数中修改person对象的name属性时,会影响到myPerson对象的值。

需要注意的是,如果我们在函数中重新分配了person参数,那么它将不再指向原始对象。例如:

function updatePerson(person) {  person = { name: "John" };}let myPerson = { name: "Jane" };updatePerson(myPerson);console.log(myPerson.name); // 输出 "Jane"

在这个示例中,我们在函数中重新分配了person参数,将其指向了一个新的对象。这并不会影响到myPerson对象的值,因为person参数现在指向了一个新的对象。

3. 使用解构赋值传递参数

在ES6中,我们可以使用解构赋值来传递参数。这使得我们可以轻松地从对象或数组中提取特定的值,并将其作为参数传递给函数。

下面是一个示例:

function printPerson({ name, age }) {  console.log(`${name} is ${age} years old.`);}let myPerson = { name: "Jane", age: 25 };printPerson(myPerson);

在这个示例中,我们定义了一个函数printPerson,它接受一个对象参数,并使用解构赋值来提取name和age属性。当我们将myPerson作为参数传递给这个函数时,函数会从myPerson对象中提取name和age属性,并将它们作为参数传递给函数。

需要注意的是,如果我们传递的对象缺少name或age属性,那么函数将无法正常工作。因此,我们应该确保传递的对象具有正确的属性。

4. 使用展开运算符传递参数

在ES6中,我们可以使用展开运算符(…)来传递参数。这使得我们可以轻松地将一个数组或对象中的所有值作为参数传递给函数。

下面是一个示例:

function printNames(name1, name2, name3) {  console.log(`${name1}, ${name2}, and ${name3} are friends.`);}let names = ["John", "Jane", "Jim"];printNames(...names);

在这个示例中,我们定义了一个函数printNames,它接受三个参数。当我们使用展开运算符将names数组作为参数传递给这个函数时,函数会将数组中的三个值分别赋值给name1、name2和name3参数。

需要注意的是,如果我们传递的数组中的元素数量不足三个,那么函数将无法正常工作。因此,我们应该确保传递的数组具有足够的元素。

5. 使用可选参数

在JavaScript中,我们可以使用可选参数来定义一个函数,这些参数可以被省略。当我们省略一个可选参数时,它的值将为undefined。

下面是一个示例:

function sayHello(name, greeting = "Hello") {  console.log(`${greeting}, ${name}!`);}sayHello("John"); // 输出 "Hello, John!"sayHello("Jane", "Hi"); // 输出 "Hi, Jane!"

在这个示例中,我们定义了一个函数sayHello,它接受两个参数:name和可选参数greeting。当我们省略greeting参数时,它的默认值为"Hello"。当我们调用sayHello函数时,可以省略greeting参数,它的值将为默认值。

需要注意的是,可选参数必须放在函数参数列表的最后面。

6. 使用剩余参数

在JavaScript中,我们可以使用剩余参数来定义一个函数,它可以接受任意数量的参数。当我们调用这个函数时,剩余参数将被收集到一个数组中。…是es6写法

下面是一个示例:

function sum(...numbers) {  let total = 0;  for (let number of numbers) {    total += number;  }  return total;}console.log(sum(1, 2, 3)); // 输出 6console.log(sum(4, 5, 6, 7)); // 输出 22

在这个示例中,我们定义了一个函数sum,它使用剩余参数来接受任意数量的参数。当我们调用sum函数时,它将把所有参数收集到一个数组中,并计算它们的总和。

需要注意的是,剩余参数必须放在函数参数列表的最后面。

到此,关于“JavaScript传参的方式有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯