13-1.函数的参数

函数的本质:

ü 函数的作用,代码重用,编写一个函数,就是为了解决一类问题。

ü 函数每次调用,都有一个结果,那么结果和什么相关呢?y = x , y = x2,y = sin(x)。和我们给定的某一个值相关的。

这就涉及到参数的问题。

​ 函数中的参数分为

形参:函数定义时小括号中的参数称为形参表示要传入什么样的值

实参:函数调用时输入的参数称为实参,具体的某个值

案例,我们需要定义一个函数,对两个数进行求和。

正是由于有了参数这么一个武器,所以我们的函数才得以重用。

多个参数由逗号 (,) 分隔

说明:

​ 在定义和调用函数的时候,对形式参数和实参要求没有那么严格。

​ 形参和实参的个数,可以不相等,程序不会出错,结果可能会出问题。

想要获取实参6,7怎么办

#13-2arguments

什么是arguments?

​ arguments是实参的一个集合;

说明:

ü arguments队形是用来接受实参的,每一个函数都有arguments对象,arguemnts只会在内部找自身的arguments,无法引用到外层的arguments

ü 我们将实参收集起来,放到一个arguments对象里,组成一个由实参构成的类数组,[实参1,实参2,实参3…..实参n]

ü 我们可以通过arguments的索引(0,1,2,3…),来访问每一个实参,

ü 访问格式:arguments[下标]

ü arguments.length:可以得到实参是个数

细节:

1) arguments[0]可以取到传入的第一个实参

2) arguments[arguments.length-1] 可以取到传入参数的最后一个实参

3) arguments的长度是由传入的实参个数决定的,而不是由定义函数时的命名参数的个数决定的

4) 没传参的时候arguments.length 为0.是个[]

5) 获取每一个实参:

#11-3.函数的返回值

我们每调用一个函数,希望得到一个什么东西呢?

y = x , y = 2x+1,y = sin(x)

实际上,在js开发中,我们调用一个函数,往往是需要通过它的处理,得到一个具体的结果。

函数中的return语句是指定函数调用的返回值

说明:

return只能在函数体中出现,如果不是的话会报语法错误

在使用ruturn语句时,函数就会停止执行,并返回指定的值,后面的语句不会被执行。

细节:

1) 没有使用return的时候,我们可以这么理解,在一个函数当中,最后一定会有一个return 语句,默认的是 return undefined。

2) 如果有 return 就是return的值。

3) 如果有return ,但是没有return后没有值,则返回undefined

​ 作业:

​ 1.函数封装(详情见文档)

#11-4.函数的作用域

什么是作用域?

首先,作用域是针对变量而言的。要定义一个变量,这个变量就有一个相应的作用域。

作用域是指变量的生效范围,在程序中,在什么范围之内可以访问,什么范围不能访问。

在js中,以函数为界,可以分为如下两种:

全局变量:不在任何函数内定义的变量就是全局变量。

局部变量:(函数内var 声明的变量)只能被函数自身读取(该变量的作用域是局部的)。

变量的规则:(变量的作用域)

1)如果一个变量在函数体内部申明,则该变量的作用域为整个函数体,在函数体外不可引用该变量:

2)如果两个不同的函数各自申明了同一个变量,那么该变量只在各自的函数体内起作用。换句话说,不同函数内部的同名变量互相独立,互不影响:

3)函数外部的变量就算是和函数内部的变量名称相同,也是两个变量,没有任何关系,彼此不发生影响

  1. 函数内部的变量,没有用var时,会逐层向上查找

(如果把值赋给尚未声明的变量,是隐式声明,不会变量提升,直接为全局变量)

**a. ** 先执行函数,再输出变量

**b. ** 没有执行函数;直接输出

变量的生存周期:

JavaScript 变量的生命期从它们被声明的时间开始。

局部变量会在函数运行以后被删除。

全局变量会在页面关闭后被删除。

函数同名的话,后写的函数覆盖先写的函数。

注意:js没有重载

#小结:

\1. 函数的参数分为形参和实参;

\2. arguments是实参的集合

\3. return是函数的返回值,也是函数的结束语句

\4. 在函数体内声明的变量为局部变量,不再函数内声明的变量为全局变量

\5. 局部变量只能在函数体内使用,全局变量可以在任意地方使用;

js上 十三、函数初步-2的更多相关文章

  1. js上 十二、函数初步-1

    11-1.引入(认识函数) ​ 引入: 说起函数,其实我们并不陌生,在初中数学中我们就接触过函数:例如我们所学的 y = 2X+1 ; 这是一个二元一次方程,也是我们数字中的函数: ​ 当我们每次输入 ...

  2. js进阶 12-8 如何知道上一个函数的返回值是什么(如何判断上一个函数是否执行成功)

    js进阶 12-8 如何知道上一个函数的返回值是什么(如何判断上一个函数是否执行成功) 一.总结 一句话总结:event的result属性即可. 1.event的result属性的实际应用场景是什么? ...

  3. JS中给函数参数添加默认值

    最近在Codewars上面看到一道很好的题目,要求用JS写一个函数defaultArguments,用来给指定的函数的某些参数添加默认值.举例来说就是: // foo函数有一个参数,名为x var f ...

  4. JS中给函数参数添加默认值(多看课程)

    JS中给函数参数添加默认值(多看课程) 一.总结 一句话总结:咋函数里面是可以很方便的获取调用函数的参数的,做个判断就好,应该有简便方法,看课程. 二.JS中给函数参数添加默认值 最近在Codewar ...

  5. Node.js 教程 06 - 函数

    前言: 本篇介绍的是Node.js中的函数,相对于上一篇会简单一点,其实和我们Javascript中的function无异. 好了,废话不多说了,我们进入正题吧. Node.js函数: [示例1:创建 ...

  6. 关于js的回调函数的一点看法

    算了一下又有好几个月没写博客了,最近在忙公司android的项目,所以也就很少抽时间来写些东西了.刚闲下来,我就翻了翻之前看的东西.做了android之后更加感觉到手机端开发的重要性,现在做nativ ...

  7. js立即执行函数

    一.JS立即执行函数的写法 方式1.最前最后加括号 (function(){alert(1);}()); 方式2.function外面加括号   (function(){alert(1);})(); ...

  8. js 数组处理函数

    本文转载自有有<js 数组处理函数> concat 将参数列表连接到原数组后面形成一个新的数组并返回,原有数组不受影响. var arr = ["a","b& ...

  9. JS字符串替换函数:Replace(“字符串1″, “字符串2″),

    JS字符串替换函数:Replace(“字符串1″, “字符串2″), 1.我们都知道JS中字符串替换函数是Replace(“字符串1″, “字符串2″),但是这个函数只能将第一次出现的字符串1替换掉, ...

随机推荐

  1. 企业级工作流解决方案(六)--微服务消息处理模型之与Abp集成

    身份认证传递 对于Abp比较熟悉的朋友应该对他里面的用户身份认证比较熟悉,他是通过实现微软提供的权限认证方式实现的,用户登录身份信息存储在System.Security.Claims.ClaimsPr ...

  2. 来看看面试必问的HashMap,一次彻底帮你搞定HashMap源码

    HashMap结构 数组+链表+红黑树 链表大于8转红黑树,红黑树节点数小于6退回链表. 存放的key-value的Node节点 static class Node<K,V> implem ...

  3. 下载器Folx怎么安装使用

    应该使用哪个下载工具?这个如果是Windows上会有无数答案的问题,在Mac上却变得异常的纠结.比如Leech和Aria2,这两款软件,前者功能相对比较简单,后者的配置又稍微有点复杂,很难找到一款相对 ...

  4. 【VUE】7.Vuex基本使用

    1. 安装Vuex npm install vuex --save 2. 导入Vuex包 import Vuex from 'vuex' Vue.use(Vuex) 3. 创建store对象 cons ...

  5. mq中nio

    MappedFile#appendMessagesInner

  6. Plant Leaves Classification植物叶子分类:基于孪生网络的小样本学习方法

    目录 Abstract Introduction PROPOSED CNN STRUCTURE INITIAL CNN ANALYSIS EXPERIMENTAL STRUCTURE AND ALGO ...

  7. charles 常用功能(七)简易接口压力测试(repeat advance 功能)

    接口请求次数.并发量.请求延迟时间均可配置 1.选中需要进行测试的接口,鼠标右键 选中[repeat advance] 设置迭代数量

  8. day4(JWT介绍)

    1.JWT介绍 1.1jwt原理 最简单理解:jwt本质就是, 把用户信息通过加密后生成的一个字符串 JWT的原则是在服务器身份验证之后,将生成一个JSON对象并将其发送回用户 { "Use ...

  9. sqlmap工具的简单使用

    0x00 sqlmap简介:sqlmap是一款针对sql漏洞的自动化注入工具,有一个非常棒的特性,即对检测与利用的自动化处理(数据库指纹.访问底层文件系统.执行命令). 官方网站下载http://sq ...

  10. 老猿学5G:3GPP 5G规范中的URI资源概念

    ☞ ░ 前往老猿Python博文目录 ░ 说明: 本文参考3GPP29.501<Principles and Guidelines for Services Definition>结合笔者 ...