JavaScript第四天 ----函数

今日补充
调试工具:1、进入函数体 2、跳出函数体
三元表达式,一定会返回值,双分支

函数

一、为什么要函数?

函数:function,是被设计为执行任务的代码块
说明:精简代码、方便复用
思想:封装
函数体就是代码块

二、函数使用

1、函数的声明语法
function 函数名 (){
...
}

2、函数的调用
函数名();
说明:可以多次调用、以及任意时刻调用(前提是声明好了)

3、扩展:
(1)函数声明的时机:是在js刚进入执行环境的时候(函数声明会提前--提到最前面),声明时机不是运行到这一行了才声明,不像我们的let变量一样
(2)所以调用函数写在声明函数的前面也可以

4、函数名命名规范
(1)和变量命名基本一致
(2)尽量使用小驼峰命名法
(3)前缀应该是为动词
(4)命名建议:常用动词约定
can(可不可以)、has(有没有)、is(是不是)、get(获取)set(设置)、load(加载)等

5、封装步骤
(1)分析有没有相同代码
(2)抽取相同代码,并给一个名字
(3) 使用这个名字 == 执行了这段代码

6、区别
循环重复代码:写完就执行
函数的复用代码:调用即执行,且可重复

三、函数传参

提高函数的灵活性

1、声明语法:function 函数名(参数1,参数2...,参数n)
调用: 函数名(1,2...,n);
可以带多个参数

2、形参和实参
(1)形参:声明函数的时候函数名旁边小括号里面的叫形参
实参:调用函数的时候函数名旁边小括号里面的叫实参
形参与实参尽量统一(数量、顺序、类型)
(2)形参相当于声明、实参相当于赋值

参数.png

逻辑中断: 逻辑或的技巧: 取默认值

  1. 当 y 没传实参时, 默认值为 undefined
  2. undefined || 0 ; 前为逻辑假,返回后面的值 0
  3. 相当于 y = 0 ; 设置了默认值
    逻辑中断.png

四、函数返回值

函数内部不需要输出结果,而是返回结果
对执行结果的扩展性更高,可以让其他的程序使用这个结果

1、用return返回值


函数返回.png

注意事项:
1、在函数体中使用 return 关键字能将内部的执行结果交给函数外部使用
2、函数内部只能运行到 1 次 return,并且 return 后面代码不会再被执行,所以 return 后面的数据不要换行写
3、return会立即结束当前函数
4、函数可以没有 return,这种情况函数默认返回值为 undefined

注意事项.png

五、作用域

作用域:变量可用性的代码范围

1、全局作用域

整个script标签内部or多个js文件
script顶层范围
注意:运行位置,在变量之后,才可以访问(并不是 书写位置))

2、块级作用域

for循环,声明初始值的变量,
样式块级变量,
只要出现大括号就是块级作用域

3、局部作用域

函数形参,是一个局部变量


变量.png

注:

在块级或者局部未声明变量,直接赋值变量,相当于 创建了一个全局变量
函数.png

4、作用域

作用域链:采取就近原则的方式来查找变量最终的值

作用域链.png

六、匿名函数

作用:解决命名冲突(避免全局变量之间的污染)

1、匿名函数

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

匿名函数语法.png

调用
匿名函数调用.png

2、立即执行函数

避免全局变量之间的污染;
无需额外调用,立即执行,本质是已经执行了的。

语法:

立即执行函数语法.png

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

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

推荐阅读更多精彩内容