博客列表 >函数参数和返回值,模板字面量和模板函数

函数参数和返回值,模板字面量和模板函数

shooter
shooter原创
2022年04月01日 15:28:09443浏览

函数的参数和返回值

效果图

代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>函数的参数和返回值</title>
  8. </head>
  9. <body>
  10. <script>
  11. let f = (a, b) => a + b;
  12. console.log(f(1, 2));
  13. //1. 参数不足:默认参数
  14. f = (a, b = 0) => a + b;
  15. console.log(f(2, 3));
  16. //2. 参数过多:...剩余参数
  17. f = (a, b) => a + b;
  18. console.log(f(1, 2, 3, 4, 5));
  19. //如何将参数接收到,剩余参数...
  20. // ...rest: 用在函数的形参中,归并
  21. f = (a, b, ...c) => console.log(a, b, c);
  22. //将多出来的3,4,5压入到数组c中
  23. console.log(f(1, 2, 3, 4, 5));
  24. let arr = [1, 2, 3, 4, 5];
  25. //将一个数组打散,变成一个个离散的值
  26. console.log(...arr);
  27. console.log(f(...arr));
  28. //与下面这条语句一样
  29. console.log(f(1, 2, 3, 4, 5));
  30. //...用在参数调用时的实参中,是解包,打散
  31. f = (...arr) => arr.reduce((a, c) => a + c);
  32. console.log(f(1, 2, 3, 4, 5, 6, 7, 8, 9, 10));
  33. //返回值:函数只能有一个返回值,默认单值返回
  34. // 需要返回多个值怎么办,数组,对象
  35. let fn = () => [1, 2, 3];
  36. let res = fn();
  37. console.log(res);
  38. fn = () => ({
  39. id: 1,
  40. name: 'admin',
  41. age: 20,
  42. });
  43. res = fn();
  44. console.log(res);
  45. </script>
  46. </body>
  47. </html>

对象字面量的简化

效果图

代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>对象字面量的简化</title>
  8. </head>
  9. <body>
  10. <script>
  11. //属性简化
  12. let user = {
  13. name: '吴彦祖',
  14. };
  15. console.log(user.name);
  16. let name = '彭于晏';
  17. user = {
  18. name,
  19. };
  20. console.log(user.name);
  21. //1. 变量name与对象属性同名
  22. // 2. 并处于相同作业域,彼此可见,可以不写变量名
  23. //2.方法简化
  24. user = {
  25. name,
  26. getName() {
  27. return 'hello,' + this.name;
  28. },
  29. };
  30. console.log(user.getName());
  31. </script>
  32. </body>
  33. </html>

模板字面量与模板函数

效果图

代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>模板字面量与模板函数</title>
  8. </head>
  9. <body>
  10. <script>
  11. //1. 模板字面量
  12. console.log('hello world');
  13. //反引号:模板字面量,支持在字符串插入变量/表达式:插值
  14. console.log(`hello worlf`);
  15. let name = '陈冠希';
  16. console.log('hello ' + name);
  17. //变量/表达式:在模板字面量,使用'${xxx}'来引用,就是一个占位符
  18. console.log(`hello ${name}`);
  19. let gender = 1;
  20. console.log(`${gender ? `男:${name}` : `女`}`);
  21. // 2. 模板函数
  22. // 使用模板字面量为参数的参数
  23. calc`数量: ${10}单价: ${500}`;
  24. // 第一个参数: 模板字面量中的"字符串字面晨"
  25. // 第二个参数: 模板字面量中的"插值"数组
  26. function calc(strings, ...args) {
  27. console.log(strings);
  28. console.log(args);
  29. console.log(args[0] * args[1]);
  30. }
  31. /**
  32. * * 模板字面量: 可以使用插值表达式的字符串
  33. * * 模板函数: 可以使用"模板字面量"为参数的函数
  34. * * 模板函数,就是在"模板字面量"之前加一个标签/标识符,而这个标签,就是一个函数名
  35. * * 模板函数的参数是有约定的, 不能乱写, 第一个是字面量数组,从第二起才是内部的占位符参数
  36. */
  37. // * 模板字面量, 也叫"模板字符串" , 是同义词,我觉得用"模板字面量"更直观,准确
  38. // * 模板函数, 有的书也翻译与"标签函数", 因为 它使用"模板字面量"做参数,称为"模板函数"更直观, 一看知识必须传一个模板字面量当参数
  39. </script>
  40. </body>
  41. </html>
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议