JavaScript学习文档(5):为什么需要函数、函数使用、函数传参、函数返回值、作用域、匿名函数、逻辑中断

本文主要是介绍JavaScript学习文档(5):为什么需要函数、函数使用、函数传参、函数返回值、作用域、匿名函数、逻辑中断,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、为什么需要函数

1、函数

2、说明

二、函数使用

1、函数的声明语法

2、函数名命名规范

3、函数调用语法

4、函数体

5、函数案例(数字求和)

(1)计算1-100之间所有数字的和

三、函数传参

1、声明语法

2、调用语法

3、函数传参

4、函数传参案例

(1)函数封装-求和

四、函数返回值

1、返回值函数的概念:

2、函数返回值

3、有返回值的函数

4、函数返回值练习

5、break和return有什么区别?

五、作用域

1、作用域

2、作用域的作用

3、根据作用域不同

4、特殊情况

5、变量的访问原则

6、作用域链

六、匿名函数

1、匿名函数

2、函数表达式

3、立即执行函数

4、转换时间案例

七、逻辑中断

1、开发中写法:

2、逻辑运算发里的短路

3、转换为Boolean型

(1)记忆:

(2)隐式转换


一、为什么需要函数

1、函数

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

2、说明

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

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

二、函数使用

1、函数的声明语法

function 函数名(){

        函数体

}

2、函数名命名规范

  • 和变量命名基本一致
  • 尽量小驼峰式命名法
  • 前缀应该为动词
  • 命名建议:常用动词约定

3、函数调用语法

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

函数名()

注意:函数不调用,就不会执行函数体里的代码

4、函数体

示例代码如下:

 // 1. 函数的声明   function sayHi() {console.log('hi~~~')}// 2. 函数调用   函数不调用,自己不执行sayHi()

5、函数案例(数字求和)

(1)计算1-100之间所有数字的和

示例代码如下:

    // 2. 求 1~100 累加和function getSum() {let sum = 0for (let i = 1; i <= 100; i++) {sum += i}console.log(sum)}getSum()

三、函数传参

1、声明语法

function 函数名(参数列表){

         函数体

}

参数列表:

  • 传入数据列表
  • 声明这个函数需要传入几个数据
  • 多个数据用逗号隔开

2、调用语法

函数名(传递的参数列表)

getSum(10,20)

3、函数传参

  • 函数求和以及默认参数

示例代码如下:

    // 函数求和// function getSum(x = 0, y = 0) {//   // x = 1//   // num1 默认的值 undefined//   document.write(x + y)// }// getSum(1, 2)// getSum()  // 0function getSum(start = 0, end = 0) {   // end = 50// 形参  形式上的参数// console.log(end)let sum = 0for (let i = start; i <= end; i++) {sum += i}console.log(sum)}getSum(1, 50)  // 调用的小括号里面 实参 - 实际的参数getSum(100, 200)  // 实参 - 实际的参数getSum()

4、函数传参案例

(1)函数封装-求和

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

示例代码如下:

    // 1. 封装函数// 给一个参数的默认值function getArrSum(arr = []) {// console.log(arr)let sum = 0for (let i = 0; i < arr.length; i++) {sum += arr[i]}console.log(sum)}getArrSum([1, 2, 3, 4, 5])getArrSum([11, 22, 33])getArrSum()  // 0

四、函数返回值

1、返回值函数的概念:

  • 当调用某个函数,这个函数会返回一个结果出来
  • 这就是有返回值的函数

2、函数返回值

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

return 数据

return 20

示例代码如下:

    function getTotalPrice(x, y) {return x + y// return 后面的代码不会被执行}let num = getTotalPrice(10, 30)document.write(num)

3、有返回值的函数

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

4、函数返回值练习

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

示例代码如下:

  // 1. 求最大值函数function getMax(x, y) {return x > y ? x : y}let max = getMax(11, 234)console.log(max)

(2)求任意数组中的最大或最小值并返回这个最大值或最小值

示例代码如下:

    function getArrValue(arr = []) {// (1)先准备一个max变量存放数组的第一个值let max = arr[0]let min = arr[0]  // 最小值// (2) 遍历比较for (let i = 1; i < arr.length; i++) {// 最大值if (max < arr[i]) {max = arr[i]}// 最小值if (min > arr[i]) {min = arr[i]}}// (3) 返回值  返回的是数组return [max, min]// return min}let newArr = getArrValue([11, 3, 55, 7, 29])console.log(`数组的最大值是: ${newArr[0]}`)console.log(`数组的最小值是: ${newArr[1]}`)

5、break和return有什么区别?

  • break结束的是循环或者是switch
  • 而我们的return结束的是函数

五、作用域

1、作用域

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

2、作用域的作用

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

3、根据作用域不同

(1)变量分为两种

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

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

4、特殊情况

  • 如果函数内部,变量没有声明,直接赋值,也当全局变量看,但是强烈不推荐
  • 但是有一种情况,函数内部的形参可以看做是局部变量。

5、变量的访问原则

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

6、作用域链

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

六、匿名函数

1、匿名函数

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

使用方式:

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

2、函数表达式

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

语法:

let fn = function(){

           //函数体

}

调用:

fn()   //函数名()

 // 函数表达式和 具名函数的不同   function fn() {}// 1. 具名函数的调用可以写到任何位置// 2. 函数表达式,必须先声明函数表达式,后调用function fun() {console.log(1)}fun()

3、立即执行函数

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

语法:

    // 1. 第一种写法(function (x, y) {console.log(x + y)let num = 10let arr = []})(1, 2);// (function(){})();// 2.第二种写法// (function () { }());(function (x, y) {let arr = []console.log(x + y)}(1, 3));

4、转换时间案例

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

分析:

  • ①:用户输入总秒数(注意默认值)
  • ②:计算时分秒(封装函数)里面包含数字补0
  • ③:打印输出

示例代码如下:

    // 1. 用户输入let second = +prompt('请输入秒数:')// 2.封装函数function getTime(t) {// console.log(t)  // 总的秒数// 3. 转换// 小时:  h = parseInt(总秒数 / 60 / 60 % 24)// 分钟:  m = parseInt(总秒数 / 60 % 60)// 秒数: s = parseInt(总秒数 % 60) let h = parseInt(t / 60 / 60 % 24)let m = parseInt(t / 60 % 60)let 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)console.log(h)

七、逻辑中断

1、开发中写法:

function fn(x, y) {x = x || 0y = y || 0console.log(x + y)}fn(1, 2)

2、逻辑运算发里的短路

  • 短路:只存在于 && 和 || 中,当满足一定条件会让右边代码不执行

  • 原因:通过左边能得到整个式子的结果,因此没必要再判断右边
  • 运算结果:无论 && 还是 || ,运算结果都是最后被执行的表达式值,一般用在变量赋值

3、转换为Boolean型

(1)记忆:

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

    console.log(Boolean('pink'))console.log(Boolean(''))console.log(Boolean(0))console.log(Boolean(90))console.log(Boolean(-1))console.log(Boolean(undefined))console.log(Boolean(null))console.log(Boolean(NaN))
(2)隐式转换
  • 有字符串的加法“”+1,结果是“1”
  • 减法–只能用于数字,它会使空字符串""转换为0
  • null经过数字转换之后会变为0
  • undefined经过数字转换之后会变为NaN
    console.log('' - 1);  //-1console.log('pink' - 1); //NaNconsole.log(null + 1);  //1console.log(undefined + 1); //NaNconsole.log(NaN + 1); //NaN

这篇关于JavaScript学习文档(5):为什么需要函数、函数使用、函数传参、函数返回值、作用域、匿名函数、逻辑中断的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101978

相关文章

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

Spring Boot 集成 Quartz并使用Cron 表达式实现定时任务

《SpringBoot集成Quartz并使用Cron表达式实现定时任务》本篇文章介绍了如何在SpringBoot中集成Quartz进行定时任务调度,并通过Cron表达式控制任务... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启动 Sprin

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器