JavaScript基础(十四)

函数

很多人一看到这两个字就头大,可能由于多年被数学摧残有不小阴影,放心,我们这里的函数不是那些东西,在编程中我们的函数指的是:

程序的基本单元,是完成特定任务的代码语句块。

我们在写程序时,可能会用到很多重复的代码,函数可以把我们重复性的东西装起来,用的时候直接调用,相当于模板。

函数可以分为两类:

系统函数自定义函数。

函数有以下几个特征:

1.可有返回值,

2.可以传递参数,

3.实现一个功能。

自定义函数(无参)

创建方法:

1.函数定义

function  函数名( ){

         js语句

        }

2.调用

函数声明后调用才能使用,一般直接函数名()就可以调用,大部分时候是我们上篇所说的通过绑定调用。

带参函数

函数名后面那个括号到底是干什么用的,人家肯定不是为了好看才加上去的,这是要介绍到我们参数

参数:   形参(制定规则)

           实参(实际的传值)

语法:

function 函数名(参数1,参数2){

           js语句;

}

调用:

事件名="函数名(参数1,参数2)"

很多同学看到这一脸懵,也不知道什么跟什么,正常,这里我们就可以用带参的方法,做一个有参函数的加法:

function add(a,b){

      console.log('a:'+a);

      console.log('b:'+b);

      console.log(a+b);

   }

   add(2,3);

//上面我们传入参数ab,这里调用的时候把ab对应的值直接传进去,打印出我们要的a的值,b的值,a+b的值。

7e6b85d857fd42d4829c463b482ba2d6.png

有的同学看到这:唉!我有一计,我只传个2行不行,不行是个什么结果:

add(2);

8980b22a777d42e2aca83e44fb0a3ac5.png

b是undefined直接找不到的,NaN还记得吗?是不是就是一个不是数字的值,运算不能执行导致,这是不是说明,我们只传入一个值,它就对应我们传进去的第一个参数的值。

那我手抖多传了一个是什么结果呢?

  add(4,3,2);

522a01f2a1ef47a2af5a3ffbda161ad5.png

结果我们可以得出,无论我们传入多少,它他与我们的参数关系式一一对应的。

想到一个好玩的,我们可以用之前学的随机数,写一个用传参写一个小游戏,要求写一个名字,随机生成这个人会成为什么样的人:

<body>

   <button οnclick="fn(prompt('请输入您的名字'))">开始测试!</button> 

</body>

<script>

   function fn(name){

//parseInt取整还记得吧

     var num=parseInt(Math.random()*10);

     document.write(num+'<br>');

//这里把数字打印出来,方便看结果对不对

     if(num<3){

      document.write(name+'会成为一个聪明的人');

     }else if(num<6){

      document.write(name+'会成为一个幽默的人');

     }else if(num<9){

      document.write(name+'会成为一个好人');

     }else{

      document.write(name+'无敌了');

     }

   }

</script> 

bedf9e67969a449db165ddf45edd8f0b.png

c0766ae0a9d64230928f1459f156a1de.png

匿名函数

这次不废话了,匿名函数就是没有名称的函数,通过变量来接收函数,再通过调用变量名来达到调用函数的目的。

定义:

var 变量名=function (参数1,参数2){

        js语句;

    }

调用:

事件名="变量名(参数1,参数2)";

例:

var num=function(a,b){
   console.log(a+b);
  }
  num(11,22);

da28e46503154c58b7c060b34824ca96.png

没有太多区别,就相当于把函数赋值给了一个变量。

自执行函数

函数声明完以后,需要调用才能够使用,一些情况下,我们需要函数声明后,无需调用就可以自己来执行,此时就需要自执行函数——无需调用自己执行。

定义:

 (function(){

   JS语句

  }(  ))

那刚学的匿名函数和它比就知道了:

var fn=function(){

   console.log('匿名函数');

  }

  fn();

  //写法一   (函数(参数))

  (function(){

   console.log('写法1');

  }());

  //写法二   (函数)(参数)

  (function(){

   console.log('写法2');

  })()

c4a7cd173429408f81cb9f71ab65ae4d.png

可以看到,后面两个函数我并没有调用,但是他们却自己在后面打印出来的,这就是自执行函数。

同时我们发现这两种写法,值得一提的是中间那个分号不要忘记(已经用黑色加重出来了),因为它外面是个括号,分号才能代表这个函数执行完毕,如果不加就会出现下面这种报错:

239820b3df3e4b11a3365a02879b91b9.png

他跟你说从哪到哪这个东西不是一个函数,

这不只是适用于这里,如果出现报错也很有可能是你某个地方分号没有加上!

最后的话,我们就可以在后面那个括号里传入参数,例:

 (function(name){

   console.log(name+'帅呆了');

  })('李二狗')

011110374d274952aefe962be56c4850.png

  (function(a,b){

   console.log(a+b);

  }(22,33))

5a1262453df24258bc253df4684477ee.png

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/802766.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【保姆级】Python项目部署到Linux生产环境(uwsgi+python+flask+nginx服务器)

1.安装python 我这里是3.9.5版本 安装依赖&#xff1a; yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make -y 根据自己的需要下载对应的python版本&#xff1a; cd /usr/local wget https://www.python.or…

springboot机场投诉管理平台-计算机毕业设计源码22030

摘要 随着航空运输业的迅速发展&#xff0c;机场的客流量不断增加&#xff0c;旅客对机场服务的质量和效率也提出了更高的要求。为了提高机场的服务质量&#xff0c;及时处理旅客的投诉&#xff0c;建立一个高效、便捷的机场投诉管理平台显得尤为重要。 本项目旨在设计与实现一…

# ffmpeg 工具使用

文章目录 ffmpeg 工具使用1.图片转换2.图片转视频3.截取片段4. 视频格式转换5. 视频转图片方法一&#xff1a;方法二&#xff1a;生成更清晰无压缩的图片方式&#xff1a; ffmpeg 工具使用 windows安装教程&#xff1a;https://blog.csdn.net/csdn_yudong/article/details/129…

Python一对一辅导答疑|Rust 德国

你好&#xff0c;我是悦创。 下面是答疑内容。 在 Rust 中&#xff0c;方法的调用方式通常取决于它们是如何定义的。在你的例子中&#xff0c;print_drink方法最初是作为一个接受Drink类型实例作为参数的关联函数&#xff08;类似于静态方法&#xff09;定义的。后来&#xff…

紫外测熔融实验结果温度和abs作折线图和求一阶导最大值

import numpy as np import pandas as pd from pyecharts.charts import Line from pyecharts import options as opts from matplotlib import pyplot as plt import xlrd # 读取 csv 文件 data pd.read_excel(F:/LJX/lc8.xls)# 假设 csv 文件中有两列数据&#xff1a;x 和 y…

[transformer] Attention is all you need

1、目的 提出一种新的网络结构&#xff0c;不用CNN或者RNN&#xff0c;只基于self-attention 2、方法 * Norm: Layer Normalization 1&#xff09;Encoder -> -> self-attention的k、v、q来自上一个encoder层 2&#xff09;Decoder -> 由于每个位置i的预测只能参考i…

跨境电商与TikTok达人带货:未来合作模式与市场机遇

随着全球社交媒体技术的不断进步和消费者行为的持续变化&#xff0c;跨境电商与TikTok达人合作的模式正展现出前所未有的多元化和专业化趋势。这种合作不仅推动了品牌的国际化进程&#xff0c;也为消费者带来了更加丰富和个性化的购物体验。本文Nox聚星将和大家探讨未来跨境电商…

php反序列化--1--PHP序列化

目录 一、什么是php序列化&#xff1f; 二、在php中怎么进行序列化&#xff1f; 三、不同数据类型的序列化后的表达方式 1、空-NULL 2、整形 3、浮点型 4、boolean型 5、字符型 6、数组 7、对象序列化-公有修饰符 8、对象序列化-私有修饰符 9、对象序列化-保护修饰…

C++ 回溯算法

什么时候不需要startIndex? 全排列&#xff1a;1在[1,2]中已经使用过了&#xff0c;但是在[2,1]中还要在使用一次1&#xff0c;所以处理排列问题就不用使用startIndex了&#xff1b;电话号码的字母组合&#xff1a;如果是多个集合取组合&#xff0c;各个集合之间相互不影响&a…

景区导航导览系统:基于AR技术+VR技术的功能效益全面解析

在数字化时代背景下&#xff0c;游客对旅游体验的期望不断提升。游客们更倾向于使用手机作为旅行的贴身助手&#xff0c;不仅因为它能提供实时、精准的导航服务&#xff0c;更在于其融合AR&#xff08;增强现实&#xff09;、VR&#xff08;虚拟现实&#xff09;等前沿技术&…

汽车免拆诊断案例 | 卡罗拉急加速抖动故障排除

车型信息 2017年改款卡罗拉&#xff0c;排量1.2T&#xff0c;行驶里程48800公里。 故障现象 车辆不管在什么状态下&#xff0c;只要是平缓加速&#xff0c;都不会有抖动。车辆静止时&#xff0c;急加速时&#xff0c;也不会有抖动。但是车速达40公里/小时以上&#xff0c;急加…

SQL注入问题

一、什么是sql注入 public class TestSql {public static void main(String[] args) {Scanner inScanner new Scanner(System.in);System.out.println("请输入用户名");String username inScanner.nextLine();System.out.println("请输入密码");String …

python-区间内的真素数(赛氪OJ)

[题目描述] 找出正整数 M 和 N 之间&#xff08;N 不小于 M&#xff09;的所有真素数。真素数的定义&#xff1a;如果一个正整数 P 为素数&#xff0c;且其反序也为素数&#xff0c;那么 P 就为真素数。 例如&#xff0c;11&#xff0c;13 均为真素数&#xff0c;因为 11 的反序…

JuiceFS缓存特性

缓存 对于一个由对象存储和数据库组合驱动的文件系统&#xff0c;缓存是本地客户端与远端服务之间高效交互的重要纽带。读写的数据可以提前或者异步载入缓存&#xff0c;再由客户端在后台与远端服务交互执行异步上传或预取数据。相比直接与远端服务交互&#xff0c;采用缓存技…

vue3配置代理

vite.config.js中的内容&#xff1a; 在这里配置访问后台的地址 import { defineConfig } from vite import vue from vitejs/plugin-vueexport default defineConfig({plugins: [vue()],server: {open: false,port: 3000,proxy: {/api: {target: http://127.0.0.1:9001, // 后…

【论文阅读】MCTformer+:弱监督语义分割的多类令牌转换器

【论文阅读】MCTformer:弱监督语义分割的多类令牌转换器 文章目录 【论文阅读】MCTformer:弱监督语义分割的多类令牌转换器一、介绍1.1 WSSS背景1.2 WSSS策略 二、联系工作2.1 弱监督语义分割2.2 transformers的可视化应用 三、MULTI-CLASS TOKEN TRANSFORMER3.1 Multi-class t…

【Apache POI】Java解析Excel文件并处理合并单元格-粘贴即用

同为牛马&#xff0c;点个赞吧&#xff01; 一、Excel文件样例 二、工具类源码 import org.apache.poi.ss.usermodel.*; import org.apache.poi.ss.util.CellRangeAddress; import org.apache.poi.xssf.usermodel.XSSFWorkbookFactory; import org.springframework.web.multip…

【Linux】进程信号 --- 信号产生

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前正在学习c和算法 ✈️专栏&#xff1a;Linux &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章有啥瑕疵&#xff0c;希望大佬指点一二 如果文章对…

【Android】活动的生命周期与启动模式

【Android】活动的生命周期与启动模式 活动的生命周期 返回栈 返回栈&#xff08;Back Stack&#xff09;是Android操作系统中用于管理用户在应用中导航历史的一种数据结构。它允许用户通过按下硬件返回键或调用系统返回功能来回到之前的操作步骤。以下是返回栈的一些关键特…

R与机器学习系列|15.可解释的机器学习算法(Interpretable Machine Learning)(中)

在上次推文中我们介绍了几种可解释机器学习算法的常见方法&#xff0c;包括置换特征重要性、偏依赖图和个体条件期望及其实现。本次我们将继续介绍其他的用来解释机器学习算法的方法。 1.特征交互&#xff08;Feature interactions&#xff09; 1.1介绍 在机器学习中&#xff0…