接之前一篇的函数。写之前的函数的时候讲的比较笼统,在这重新写一下函数的内容。

函数:

  之前提过,函数就是代码复用的一种机制或是将代码封装成功能的代码段。函数的声明在这边就不多提了,因为相对来说比较简单。除了正常的函数声明之外,还有一种函数的声明方式,就是函数表达式。它的格式如下:

var fun=function(){
console.log("啦啦啦");
}
fun();

  先是用var关键字来定义一个变量,在等号的右边写一个匿名函数,匿名函数,顾名思义也就是没有名字的函数,匿名函数在调用的时候,是用变量名来加一个小括号的形式调用它。值得注意的是,在用函数表达式声明函数的时候记得要再花括号后加一个分号,不然程序有可能出现一些不可预知的错误。比如后面如果跟了个自执行函数的话,就有可能报错或者出现一些跟我们想的不一样的结果。

  这里提到了个自执行函数,那么什么是自执行函数呢?自执行函数是没有名字的,定义了之后马上调用的函数。这种函数多用于一次性使用的时候。它得格式如下:

(function () {
console.log("啦啦啦");
})(); //------------------------------分割线---------------------------
(function () {
console.log("哈哈哈");
}());

  第一眼看感觉有点复杂,那要怎么理解记忆呢?我们都知道,函数的调用是用函数名+括号的形式来调用的。那么单独使用函数名会输出什么结果呢?比如下面这段代码:

function fun(){
console.log("啦啦啦");
}
console.log(fun);

在控制台打印的结果为:

  由此我们可以知道,使用函数表达式定义函数之后,变量跟函数体是等价的。因此,自执行函数就很好记了,就是把以前写函数名的地方改成了函数体的形式,并且在外面加了一层括号来指定自执行函数的区域。自执行函数的好处就是不需要定义变量名,而且定义了之后马上调用。

  除此之外,函数还有很多其他的作用,比如函数还可以作为一个参数传入另一个函数之中。根据前面自执行函数演示的代码可以知道,当单独打印函数名的时候,会打印出整个函数体。函数是一种数据类型,如果用typeof来打印一下函数名的时候,会打印出一个function的值。

  比如下面这段代码,他在控制台输出的结果就是function。由此我们可以知道,函数是有数据类型的,并且它的类型是function。

function fun(){
console.log("啦啦啦");
}
console.log(typeof fun);

  因此,函数可以作为一个参数来传入另一个函数之中。那具体是怎么使用的呢?可以看下面的代码。

function getResult(a, b, fn) {
return fn(a, b);
}

  我们在getResult这个函数中定义了三个参数,a,b,fn。这三个参数都只是形参,因此可以是任意值。首先我们先分析一下这段代码,这段代码定义了一个函数名为getResult的函数。这个函数有三个参数a,b,fn。它的返回值是一个函数名为fn,参数为a,b的函数。

  在这里,我们把fn看成了一个函数来使用,并且把getResult函数中的形参a和b来当做fn函数中的实参。这样,我们就实现了把函数当做变量传入另一个函数中。在函数调用的时候,我们就可以用这种形式来表示:

var f1 = function(a,b){
return a*b;
}; console.log(getResult(15, 60, f1));

  在这里,我们先用函数表达式的方法定义了一个名叫fn的函数,并且把他当成参数传进了getResult函数中。函数执行的结果为900;这样,我们就已经完成了把函数作为一个参数传入另一个函数中。不过,这段代码还简化一下。

  因为在定义了函数之后,函数名跟函数体是等价的,所以,上面代码还可以简写成这样。

Console.log(getResult(15,60,function(a,b){
return a*b;
}));

  说完了这些,然后在说说JS中一些跟其他语言不同的地方,比如函数的重载,在JS中是没有函数重载的。既然说JS没有重载的话,就不得不提一下什么是重载了。所谓的重载就是函数名相同,但是函数的形参个数不同,或者形参的数据类型不同,这样就构成了函数的重载。

function getSum(a, b) {
return a - b;
}
function getSum(a, b, c) {
c = c || 0;
return a + b + c;
}
console.log(getSum(1, 2));

  比如说上面这段代码,程序运行的结果是3,为什么是3呢?在JS中,如果有重名的函数,那么后面的函数会将前面的函数覆盖掉。所以这段代码只会执行后面那个函数,而前面的函数则被后面的函数给覆盖掉了。

  还有一个就是作用域的问题,跟其他语言不同的是,JS中是没有块级作用域的,所谓的块级作用域,就是一个{}之间包裹的区间。但是,JS中有全局作用域和局部作用域。全局作用域就是同一个页面中的script标签之间的区域。在全局作用域中的变量是可以在任何地方都能访问到的。而局部作用域则是函数内部的作用域,在函数内部定义的变量则是局部变量。在这里,不得不提一点就是变量的赋值前都会有一个var关键字,如果在函数内部没有用var定义的变量,这个变量就会变成全局变量,会造成变量的污染。

 

JS入门(四)的更多相关文章

  1. 转:arcgis api for js入门开发系列四地图查询

    原文地址:arcgis api for js入门开发系列四地图查询 arcgis for js的地图查询方式,一般来说,总共有三种查询方式:FindTask.IdentifyTask.QueryTas ...

  2. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

  3. Ember.js入门教程、博文汇总

    第一章 对象模型 Ember.js 入门指南——类的定义.初始化.继承 Ember.js 入门指南——类的扩展(reopen) Ember.js 入门指南——计算属性(compute properti ...

  4. 让我们一起学习《Node.js入门》一书吧!

    Node.js入门 读完本书之后,你将完成一个完整的web应用,该应用允许用户浏览页面以及上传文件. 里面对一些知识的讲解,让你略窥Node.js的门径.最好一段代码一段代码的写下来,我的习惯是手里拿 ...

  5. Python爬虫入门四之Urllib库的高级用法

    1.设置Headers 有些网站不会同意程序直接用上面的方式进行访问,如果识别有问题,那么站点根本不会响应,所以为了完全模拟浏览器的工作,我们需要设置一些Headers 的属性. 首先,打开我们的浏览 ...

  6. 转 Python爬虫入门四之Urllib库的高级用法

    静觅 » Python爬虫入门四之Urllib库的高级用法 1.设置Headers 有些网站不会同意程序直接用上面的方式进行访问,如果识别有问题,那么站点根本不会响应,所以为了完全模拟浏览器的工作,我 ...

  7. d3.js 入门指南

    说到数据可视化,我们会行到很多优秀的框架,像echarts.highcharts,这些框架很优雅,健壮,能满足我们对可视化的大部分需求,但是缺点也很明显,就是这些框架几乎是不可定制化的,当遇到特殊的需 ...

  8. 极简 Node.js 入门 - 2.4 定时器

    极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...

  9. 1. web前端开发分享-css,js入门篇

    关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人与人的教育背景与成长环境心理活动都有差别,但就别人的心得再结合自己的特点,然后探索适合自己的学 ...

  10. JS入门之ActiveXObject对象(转载)

    JS入门之ActiveXObject对象   此对象提供自动化对象的接口.   function ActiveXObject(ProgID : String [, location : String] ...

随机推荐

  1. C#中如何使用IComparable<T>与IComparer<T>接口(转载)

    本分步指南描述如何使用两个接口: IComparer和IComparable.在同一篇文章中讨论这些接口有两个原因.经常在一起,使用这些接口和接口类似 (并且有相似的名称),尽管它们用于不同用途. 如 ...

  2. ubuntu vi编辑insert时上下左右建为ABCD

    ubuntu  在vi编辑insert时上下左右建不能移动光标而是输出ABCD,backspace也不能起删除作用, 开始我退出insert模式就能够移动和删除了,不过这样太麻烦很不适应, 只要一次执 ...

  3. 让EFCore更疯狂些的扩展类库(二):查询缓存、分部sql、表名替换的策略配置

    前言 上一篇介绍了扩展类库的功能简介,通过json文件配置sql语句 和 sql语句的直接执行,这篇开始说明sql配置的策略模块:策略管理器与各种策略的配置. 类库源码:github:https:// ...

  4. ArcGIS 网络分析[1] 介绍与博文目录【更新中】

    网络分析是个热点,理论上是属于计算机图形学和数据结构的,GIS以此为基础做出应用. 以下列举本人在学习中遇到的网络分析问题与经验总结. 平台:Windows 10操作系统,ArcGIS for Des ...

  5. Dubbo源码学习文章目录

    目录 Dubbo源码学习--服务是如何发布的 Dubbo源码学习--服务是如何引用的 Dubbo源码学习--注册中心分析 Dubbo源码学习--集群负载均衡算法的实现

  6. JAVA_file(2)

    几种不太安全的: 1. new File(path),这个方法的路径到底在那里取决于调用java命令的起始位置定义在哪里, tomcat/bin下面的catalina.bat调用了java,所以在to ...

  7. SQL Server 安装报错找不到vc_red.msi

    问题描述: 今天给 WIN 7 SP1 操作系统安装 SQL Server 2014 ,报错找不到vc_red.msi   (图片来源网络,请忽略2012字样..)   问题解决: 1.由于安装程序提 ...

  8. 完成OSS.Http底层HttpClient重构封装 支持标准库

    OSS.Http项目对于.Net Standard标准库的支持已经迁移完毕,OSS开源系列两个最底层的类库已经具备跨运行时支持的能力.由于OSS.Http类库是几年前我参照RestSharp的思路,完 ...

  9. 【小分享】Date对象封装,时间格式化函数time()

    今天再来分享下Date的应用知识点 先看效果,类似于php里边的time('yyyy-mm-dd')用法,但是我这里没有完全依照php的参数格式来,如果有需要稍微修改一下就行. 首先,明确需要用到的参 ...

  10. python报错UnicodeDecodeError: 'ascii' codec can't decode byte 0xe8 in position 0 解决方案

    环境:mac+python 2.7 场景描述:在使用python修改excel内容修改表格内容为中文保存时报以下错误 此时已经设置了utf-8了 但保存时仍然报错错 此时将python中的中文使用un ...