JS函数(阮一峰)

函数是一段可反复调用的代码块。
函数能接受输入参数,不同参数返回不同的值。

1. 概述

1.1 声明

  • function命令
  • 函数表达式
  • Function构造函数

1.2 函数的重复声明

一个函数被多次声明,后面覆盖前面。
由于函数名提升,前面任何时候都是无效的。

1.3 圆括号运算符、return语句和递归

  • 圆括号运算符:圆括号中可加入函数参数
  • return语句
  • 递归(recursion):函数可以调用自身

1.4 第一等公民

将函数看作一种值,与其他值地位相同。

1.5 函数名的提升

  • function命令声明函数,提升到代码头部。
  • 同时采用function命令赋值语句声明一个函数,最后总是采用赋值语句定义。

1.6 不能在条件语句中声明函数

由于函数名提升,条件语句中声明函数可能是无效的。
要达到在条件语句中声明函数的目的,只有使用函数表达式。

2. 函数的属性和方法

2.1 name属性

返回函数的名字。

2.2 length属性

返回函数预期传入的参数个数。

2.3 toStrion()

返回一个字符串,内部是函数的源码(包括函数内部注释)。

3. 函数的作用域

3.1 定义

ES5规范,JS只有两种作用域:

  • 全局作用域:函数外部声明的变量就是全局变量(global variable),可在函数内读取。
  • 函数作用域:函数内部定义的变量就是局部变量(local variable),外部无法读取。
  • 局部变量会在该作用域内覆盖同名全局变量。

ES6新增块级作用域。

3.2 函数内部变量提升

函数内部var声明的变量,变量声明会被提升到函数体头部。

3.3 函数本身的作用域

函数执行时的作用域是定义时的作用域,不是调用时的作用域。

4. 参数

4.1 概述

函数运行需要提供的外部数据。

4.2 参数的省略

  • JS允许省略参数。
  • 函数length属性只反映预期传入参数个数。
  • 要省略靠前的参数,显示传入undefined。

4.3 传递方式

  • 传值传递(passes by value)传拷贝
    参数是原始类型的值(数值、字符串、布尔值)。
    函数体内部修改参数不影响外部。
  • 传址传递(pass by reference)传地址
    参数是复合类型的值(数组,对象,其他函数)。
    函数内部修改会影响原始值。

4.4 同名参数

如果有同名参数,取后出现的那个值。

4.5 arguements对象

  • arguments对象包含函数运行时的所有参数。
  • 只有在函数体内部才能使用。
  • 正常模式可修改,严格模式修改无效但不报错。
  • arguments.length 判断函数调用时到底带几个参数。
  • 是伪数组,数组专有的方法不能在arguments对象上直接使用。
  • callee属性,返回它所对应的原函数。(这个属性严格模式禁用)

5. 函数其他知识点

5.1 闭包

如果一个函数使用了它范围外面的变量,那么这个函数+这个变量就叫做闭包。
闭包:https://zhuanlan.zhihu.com/p/22486908

5.2 立即调用的函数表达式

6. eval命令

eval 命令的作用是,将字符串当作语句执行。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容