当前位置: 首页 > news >正文

JavaScript入门——(5)函数

1、为什么需要函数

函数:function,是被设计为执行特定任务的代码块

说明:函数可以把具有相同或相似逻辑的代码“包裹”起来,通过函数调用执行这些被“包裹”的代码逻辑,有利于精简代码方便复用。

比如之前使用的alert()、prompt()和console.log()都是一些js函数,只不过已经封装好了,可以直接使用的。

2、函数使用

2.1 函数的声明

function 函数名(){函数体
}

例: 

function sayHi(){document.write('hai~~')
}

 2.2 函数名命名规范

和变量名命名基本一致

尽量小驼峰式命名法

前缀应该为动词

命名建议:常用动词约定

动词含义
can判断是否可以执行某个动作
has判断是否含义某个值
is判断是否为某个值
get获取某个值
set设置某个值
load

加载某些数据

如:

function getName(){}

function addSquares(){} 

2.3 函数调用 

调用语法:

函数调用,这些函数体内的代码逻辑会被执行

函数名()

注意:声明(定义)的函数必须调用才会真正被执行,使用()调用函数

函数一次声明可以多次调用,每一个函数调用函数体里面的代码会重新执行一次

2.4 函数体

函数体是函数的构成部分,它负责将相同或相似代码“包裹”起来,直到函数调用时函数体的代码才会被执行。函数的功能代码都要写在函数体当中。

// 打招呼
function sayHi(){console.log('嗨~')
}
sayHi()

2.5 封装练习

1.封装一个函数,计算两个数的和

2.封装一个函数,计算1-100之间所有数的和

    <script>// 1.求2个数的和function getSum(){let num1 = +prompt(`请输入第一个数`)let num2 = +prompt(`请输入第二个数`)console.log(num1 + num2)}getSum()// 2.求1-100累加和function getSum100(){let sum = 0for(let i = 1;i <= 100; i++){sum += i}console.log(sum)}getSum100()</script>

3、函数传参

3.1 语法格式

 参数列表

  • 传入数据列表
  • 声明这个函数需要传入几个数据
  • 多个数据用逗号隔开
// 声明语法
function 函数名(参数列表){函数体
}//单个参数
function getSquare(num1){document.write(num1 * num1)
}//多个参数
function getSum(num1,num2){document.write(num1 + num2)
}//调用语法
函数名(传递的参数列表)//例
getSquare(8)
getSum(10,20)// 在调用函数时,需要传入几个数据就写几个,用逗号隔开
        function getSum(start,end){// 形参 形式上的参数let sum = 0for(let i = 1;i <= end; i++){sum += i}console.log(sum)}getSum(1,50)  // 调用的小括号里面 实参 - 实际的参数getSum(100,200) // 实参 - 实际的参数

 3.2 参数传递过程

 

3.3 形参和实参 

形参:声明函数时写在函数名右边小括号里的叫形参(形式上的参数),默认值是undefined

实参:调用函数时写在函数名右边小括号里的叫实参(实际上的参数)

形参可以理解为是在这个函数内声明的变量(比如num1 = 10)实参可以理解为是给这个变量赋值

在开发中尽量保存形参和实参个数一致

3.4 函数封装求和 

采取函数封装的形式:输入2个数,计算两者的和,打印到页面中

        function getSum(num1,num2){document.write(num1 + num2)}getSum(1,3)

3.5 函数传参-参数默认值 

形参:可以看做变量,但是如果一个变量不给值,默认是什么?

  • undefined

但是如果用户不输入实参,那么3.4函数封装求和,则出现undefined + undefined结果是什么?

  • NaN

可以改进下,用户不输入实参,可以给形参默认值,可以默认为0,这样程序更严谨,如下操作:

        function getSum(x=0,y=0){document.write(x + y)}getSum()//结果是0,而不是NgetSum(1,2) // 结果是3

说明:这个默认值只会在缺少实参参数传递时才会被执行,所以有参数会优先执行传递过来的实参,否则默认为undefined 

3.6 函数封装-求学生总分

学生的分数是一个数组,计算每个学生的总分

分析:

①:封装一个求和函数

②:传递过去的参数是一个数组

③:函数内部遍历数组求和

        // 1.封装函数// 给一个参数的默认值function getArrSum(arr = []){//console.log(arr)for(let i = 0; i< arr.length;i++){sum += arr[i]}console.log(sum)}getArrSum([1,2,3,4,5]) // 15getArrSum([11,22,33]) // 66getArrSum() // 0
        // 求 n~m 的累加和function getSum(n = 0, m = 0){let sum = 0for(let i = n; i <= m; i++){sum += i}console.log(sum)}let num1 = +prompt('请输入起始值:')let num2 = +prompt('请输入结束值:')// 调用函数getSum(num1,num2)

4、函数返回值

4.1 返回值概念

返回值函数的概念:

  • 当调用某个函数,这个函数会返回一个结果出来
  • 这就是有返回值的函数
  • 在之前已经接触了很多的函数具备返回值,,如下:
let result = prompt('请输入你的年龄:')
let result2 = parseInt('111')
  • 只是这些函数是js底层内置的,我们可以直接使用
  • 当然有些函数,则没有返回值
alert('我是弹框,不需要返回值')

 4.2 函数返回值语法

当函数需要返回数据出去时,用return关键字

return 数据

 4.3 使用函数返回值

        // 函数的返回值function fn(){return 20}// 相当于执行了 fn()小括号是调用者   fn() = 20// return 的值返回给调用者//console.log(fn())let re = fn()console.log(re) // 20

 细节:

  • 在函数体中使用return关键字能将内部的执行结果交给函数外部使用
  • return后面代码不会再被执行,会立即结束当前函数,所以return后面的数据不要换行写
  • return函数可以没有return,这种情况函数默认返回值为undefined

4.4 函数返回值练习 

1.求任意2个数中的最大值,并返回

2.求任意数组中的最大值并返回这个最大值

3.求任意数组中的最小值并返回这个最小值

断点调试:进入函数内部看执行过程  F11

        // 1.求最大值函数function getMax(x,y){return x > y ? x : y}let max = getMax(1,2)console.log(max)  // 2
        // 2.求任意数组的最大值,并且返回function getArrValue(arr = []){// 先准备一个manx变量存放数组的第一个值let max = arr[0]// 遍历比较for(let i = 1; i < arr.length; i++){if(max < arr[i]){max = arr[i]}}// 返回值return max}let max = getArrValue([1,3,4,5,8,9])console.log(max)
        // 3.求任意数组的最小值,并且返回function getArrValue(arr = []){// 先准备一个manx变量存放数组的第一个值let min = arr[0]// 遍历比较for(let i = 1; i < arr.length; i++){if(min > arr[i]){min = arr[i]}}// 返回值return min}let min = getArrValue([1,3,4,5,8,9])console.log(min)

 注意:返回多个数据,是使用数组来实现的

        // 求任意数组的最小值和最大值,并且返回function getArrValue(arr = []){// 先准备一个manx变量存放数组的第一个值let min = arr[0]let max = arr[0] // 最大值// 遍历比较for(let i = 1; i < arr.length; i++){if(min > arr[i]){min = arr[i]}// 最小值if(max < arr[i]){max = arr[i]}}// 返回值return [min,max]  }let newArr = getArrValue([1,3,4,5,8,9])console.log(newArr)

4.5 函数细节补充 

两个相同的函数后面的会覆盖前面的函数(就近原则)

JavaScript中 实参的个数和形参的个数可以不一致

  • 如果形参过多 会自动填上undefined(了解即可)
  • 如果实参过多 那么多余的实参会被忽略(函数内部有一个arguments,里面装着所有的实参)

函数一旦碰到return就不会再往下执行了 函数的结束用return

5、作用域

通常来说,一段程序代码中所用到的名字并不总是有效和可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域。

作用域的使用提高了程序逻辑的局部性,增强了程序的可靠性,减少了名字冲突。

全局作用域(全局有效)

作用于所有代码执行的环境(整个script标签内部)或者一个独立的js文件

局部作用域(局部有效)

作用于函数内的代码环境,就是局部作用域。因为跟函数有关系,所以也成为函数作用域。

在JavaScript中,根据作用域的不同,变量可以分为:

全局变量 (函数外部let 的变量)

全局变量在任何区域都可以访问和修改

局部变量(函数内部let的变量)

局部变量只能在当前函数内部访问和修改 

    <script>let num = 10 // 全局变量console.log(num)function fn(){console.log(num)}fn()// 2. 局部变量function fun(){let str = 'hi'}console.log(str)  //报错:str is not defind</script>

 注意:

  • 如果函数内部,变量没有声明,直接赋值,也当全局变量看,强烈不推荐
  • 但是有一种情况,函数内部的形参可以看做是局部变量
    <script>function fn(){num = 10 // 全部变量来看   强烈不允许}fn()console.log(num)//10function fun(x,y){// 形参可以看作是函数的局部变量console.log(x)}fun(1,2)  //1console.log(x) // 错误的</script>

变量的访问原则

  • 只要是代码,就至少有一个作用域
  • 写在函数内部的局部作用域
  • 如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域
  • 访问原则:在能够访问到的情况下,先局部,局部没有在找全局 
  • 采取就近原则的方式来查找变量最终的值

 

123,先局部后全局

 

 0,采取就近原则的方式来查找变量最终的值

案例3:结果是几?

a的值是4

b的值是22

6、匿名函数

具名函数

声明:function fn() {}

调用:fn()

匿名函数

function() {}

没有名字的函数,无法直接使用

使用方式:

  • 函数表达式
  • 立即执行函数

6.1 函数表达式

将匿名函数赋值给一个变量,并且通过变量名称进行调用,这个称为函数表达式

let fn = function () {// 函数体
}
//调用
fn() // 函数名()//其中函数的形参和实参使用跟具名函数一致
    <script>// 1.函数表达式fn(1,2)//错误 不能接受函数在初始化之前使用let fn = function(){// console.log('我是函数表达式');console.log(x + y);}// fn() // 我是函数表达式fn(1,2) // 3// 函数表达式和具名函数的不同    // 1.具名函数的调用可以写到任何位置// 2.函数表达式,必须先声明表达式,后调用fun()function fun(){console.log(1);}// fun()</script>

6.2 立即执行函数

场景介绍:避免全局变量之间的污染

//方式1
(function () { console.log(11) })();//方式2
(function () { console.log(11) }());// 不需要调用,立即执行
    <script>(function(){let num = 10})();  //立即执行函数要加封号,不然会报错,最后这个括号是调用函数(function(){let num = 20})();//方式1(function(x,y){console.log(x + y)})(1,2);//方式2(function (x,y) {console.log(x + y)} (1,3));</script>

注意:多个立即执行函数要用;隔开,要不然会报错

7、综合案例

转换时间案例

需求:用户输入秒数,可以自动转换为时分秒

分析:

①:用户输入总秒数(注意默认值)

②:计算时分秒(封装函数)里面包含数字补0

③:打印输出

计算公式:计算时分秒

小时: h = parseInt(总秒数 / 60 / 60 % 24)

分钟:m = parseInt(总秒数 / 60 % 60)

秒数: s = parseInt(总秒数 % 60)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>// 1.用户输入let second = +prompt('请输入秒数:')// 2.封装函数function getTime(t){// console.log(t); // 总的秒数// 3.转换//小时: h = parseInt(总秒数 / 60 / 60 % 24)//分钟:m = parseInt(总秒数 / 60 % 60)//秒数: s = parseInt(总秒数 % 60)h = parseInt(t / 60 / 60 % 24)m = parseInt(t / 60 % 60)s = parseInt(t % 60)h = h < 10 ? '0' + h : hm = m < 10 ? '0' + m : ms = s < 10 ? '0' + s : s// console.log(h,m,s)return `转换完毕之后是${h}小时${m}分${s}秒`}let str = getTime(second)document.write(str)</script>
</body>
</html>

8、逻辑中断

在开发中,会见到以下写法:

其实类似参数的默认值写法

8.1 逻辑运算符里的短路

  • 短路:只存在于&&和||中,当满足一定条件会让右边代码不执行
符号短路条件
&&左边为false就短路
||左边为true就短路
  • 原因:通过左边能得到整个式子的结果,因此没必要在判断右边 
  • 运算结果:无论&&还是||,运算结果都是最后被执行的表达式值,一般用在变量赋值

如果&&两边都是真,则返回最后一个真值

如果||都是真,则输出第一个真值

9、转换为Boolean型 

9.1显示转换

Boolean(内容)

记忆:''、0、undefined、null、false、NaN转换为布尔值后都是false,其余则为true

9.2 隐式转换

  1. 有字符串的加法"" +1 ,结果是"1"
  2. 减法 - (像大多数数学运算一样)只能用于数字,它会使空字符串""转换为0
  3. null经过数字转换之后会变为0
  4. undefined经过数字转换之后会变为NaN

相关文章:

JavaScript入门——(5)函数

1、为什么需要函数 函数&#xff1a;function&#xff0c;是被设计为执行特定任务的代码块 说明&#xff1a;函数可以把具有相同或相似逻辑的代码“包裹”起来&#xff0c;通过函数调用执行这些被“包裹”的代码逻辑&#xff0c;有利于精简代码方便复用。 比如之前使用的ale…...

数据库sql查询成绩第二高

select * from propro; #查询成绩第二高 select max(id) from propro where id <(select max(id) from propro); #查询成绩第二高的第二种方式 select * from (select * from propro order by id desc limit 2) as b order by id asc limit 1;...

十五、异常(5)

本章概要 异常限制构造器 异常限制 当覆盖方法的时候&#xff0c;只能抛出在基类方法的异常说明里列出的那些异常。这个限制很有用&#xff0c;因为这意味着与基类一起工作的代码&#xff0c;也能和导出类一起正常工作&#xff08;这是面向对象的基本概念&#xff09;&#…...

途虎养车上市、京东养车“震虎”,如何突围汽车后市场?

“汽车后市场第一股”终于来了&#xff01; 赶在十一黄金周之前&#xff0c;途虎养车股份有限公司(09690.HK&#xff0c;下称“途虎养车”)于9月26日挂牌港交所&#xff0c;开盘价为28港元/股&#xff0c;与发行价持平&#xff1b;IPO首日报收29.50港元/股&#xff0c;涨幅5.3…...

【算法与数据结构】--算法基础--算法入门

一、什么是算法&#xff1f; 算法是一组有序的操作步骤&#xff0c;用于解决特定问题或执行特定任务。它是一种精确而有限的计算过程&#xff0c;以输入数据作为起点&#xff0c;经过一系列明确定义的步骤&#xff0c;最终产生输出结果。算法可以看作是一种计算机程序的抽象&a…...

AnyDesk密钥

最近最新的密钥&#xff1a;7K2CV32ER6T8F8I 这款软件应该是目前用的最好的可以免费的软件了&#xff0c;记录一下密钥...

C#(Csharp)我的基础教程(二)(我的菜鸟教程笔记)-属性和字段的探究与学习

目录 1、字段字段特点&#xff1a;2、属性属性的特点 1、字段 字段是定义在方法外面的变量&#xff0c;是成员变量&#xff0c;主要是为了类的内部数据交换使用&#xff0c;字段一般是用private修饰&#xff0c;也可以用readonly修饰&#xff0c;表示只读字段&#xff0c;其它…...

Programming abstractions in C阅读笔记:p176-p178

《Programming Abstractions In C》学习第59天&#xff0c;p176-p178总结。 一、技术总结 1.addtive sequences tn tn-1 tn-2 序列&#xff1a;3, 7, 10, 17, 27, 44, 71, 115, 186, 301, 487, 788, 1275, … p177, As a general class, the sequences that follow this…...

LeetCode-496-下一个更大元素

题目描述&#xff1a; 题目链接&#xff1a;LeetCode-496-下一个更大元素 解题思路&#xff1a; 方法一&#xff1a;暴力 方法二&#xff1a;单调栈 方法一代码实现&#xff1a; class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {// 最笨的方法&am…...

C++中的Lambda表达式

一、为什么要有lambda表达式 struct Goods {string _name; // 名字double _price; // 价格int _evaluate; // 评价Goods(const char* str, double price, int evaluate):_name(str), _price(price), _evaluate(evaluate){} }; 对于一个Goods类&#xff0c;需要对其中3个成员分…...

dockerfile搭建lnmp

systemctl stop firewalld systemctl disable firewalld setenforce 0 docker network create --subnet172.18.0.0/16 --opt "com.docker.network.bridge.name""docker1" mynetwork #部署nginx&#xff08;容器IP 为 172.18.0.10&#xff09; mkdir /…...

python之数据库操作详解

一般来说&#xff0c;我们对数据库里的操作需要先连接&#xff0c;创建游标对象&#xff0c;然后通过游标对象执行SQL语句去对SQL的数据进行操作&#xff0c;本篇文章旨在记录与科普。 1.cursor相关 元组是不可变的数据类型&#xff0c;只能查询&#xff0c;不能修改&#xf…...

完成flex布局与float布局

一、flex布局 <style>.nav {display: flex;background-color: #f8f8f8; /* 导航栏背景颜色 */}.nav a {flex: 1;display: flex;align-items: center;justify-content: center;padding: 14px 16px;text-decoration: none;color: #555555; /* 导航栏文字颜色 */}.nav a:ho…...

ThinkPHP团购拼购商城源码/带分销团购商城网站源码/完美版

ThinkPHP团购拼购商城源码&#xff0c;带分销团购商城网站源码&#xff0c;很完美的一套基于ThinkPHP开发的团购分销商城源码&#xff0c;界面也很大气&#xff0c;站长亲测。有需要的可以借鉴一下。 下载地址&#xff1a;https://bbs.csdn.net/topics/613231434...

awvs 中低危漏洞

低危 X-Frame-Options Header未配置 查看请求头中是否存在X-Frame-Options Header字段 会话Cookie中缺少secure属性(未设置安全标志的Cookie) 当cookie设置为Secure标志时&#xff0c;它指示浏览器只能通过安全SSL/TLS通道访问cookie。 未设置HttpOnly标志的Cookie 当cookie设置…...

openGauss学习笔记-95 openGauss 数据库管理-访问外部数据库-postgres_fdw

文章目录 openGauss学习笔记-95 openGauss 数据库管理-访问外部数据库-postgres_fdw95.1 使用postgres_fdw95.2 postgres_fdw下推主要成分95.3 常见问题95.4 注意事项 openGauss学习笔记-95 openGauss 数据库管理-访问外部数据库-postgres_fdw openGauss的fdw实现的功能是各个…...

并不止于表面理论和简单示例——《Python数据科学项目实战》

Python 现在可以说是运用最广泛的编程语言之一&#xff0c;使用 Python 的人不只局限在计算机相关专业的从业者,很多来自金融领域、医疗领域以及其他我们无法想象的领域的人,每天都在使用 Python处理各种数据、使用机器学习进行预测以及完成各种有趣的工作。 长久以来&#xff…...

skywalking功能介绍

目标 前置&#xff1a;性能监控-微服务链路追踪skywalking搭建-CSDN博客 使用skywalking进行链路监控&#xff0c;找到应用的时间消耗再哪。 服务 服务信息 请求接口后查看skywalking&#xff0c;可以看到有一个请求&#xff0c;响应时间为1852ms&#xff0c;性能指数Apdex…...

c++桥接模式,中介者模式应用实现状态跳转

上图为例&#xff0c;按上述两种方式实现的模式跳转&#xff0c;如果在原先的三种模式之间再增加多一种模式&#xff0c;就会引起每个模式都会要求改变&#xff0c;并且逻辑混乱&#xff0c;因此更改模式为桥接中介者访问&#xff0c;将抽象和实现分离&#xff0c;实现之间采用…...

【SpringCloud】Ribbon负载均衡原理、负载均衡策略、饥饿加载

&#x1f40c;个人主页&#xff1a; &#x1f40c; 叶落闲庭 &#x1f4a8;我的专栏&#xff1a;&#x1f4a8; c语言 数据结构 javaEE 操作系统 Redis 石可破也&#xff0c;而不可夺坚&#xff1b;丹可磨也&#xff0c;而不可夺赤。 Ribbon 一、 Ribbon负载均衡原理1.1 负载均…...

浅谈 React Hooks

React Hooks 是 React 16.8 引入的一组 API&#xff0c;用于在函数组件中使用 state 和其他 React 特性&#xff08;例如生命周期方法、context 等&#xff09;。Hooks 通过简洁的函数接口&#xff0c;解决了状态与 UI 的高度解耦&#xff0c;通过函数式编程范式实现更灵活 Rea…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

Leetcode 3576. Transform Array to All Equal Elements

Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接&#xff1a;3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到&#xf…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

如何在看板中体现优先级变化

在看板中有效体现优先级变化的关键措施包括&#xff1a;采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中&#xff0c;设置任务排序规则尤其重要&#xff0c;因为它让看板视觉上直观地体…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练

前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1)&#xff1a;从基础到实战的深度解析-CSDN博客&#xff0c;但实际面试中&#xff0c;企业更关注候选人对复杂场景的应对能力&#xff08;如多设备并发扫描、低功耗与高发现率的平衡&#xff09;和前沿技术的…...

服务器硬防的应用场景都有哪些?

服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式&#xff0c;避免服务器受到各种恶意攻击和网络威胁&#xff0c;那么&#xff0c;服务器硬防通常都会应用在哪些场景当中呢&#xff1f; 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...

多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验

一、多模态商品数据接口的技术架构 &#xff08;一&#xff09;多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如&#xff0c;当用户上传一张“蓝色连衣裙”的图片时&#xff0c;接口可自动提取图像中的颜色&#xff08;RGB值&…...

什么是EULA和DPA

文章目录 EULA&#xff08;End User License Agreement&#xff09;DPA&#xff08;Data Protection Agreement&#xff09;一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA&#xff08;End User License Agreement&#xff09; 定义&#xff1a; EULA即…...