(1)普通函数:这种函数是我们日常使用中用的最多的,用function关键字定义的函数.这也是符合多种语言定义的。

function foo(){
// code
}

(2)箭头函数:用=>运算符定义的函数.这个是ES6的语法。

const foo = () => {
// code
}

(3)方法:在class中定义的函数。

class C {
foo(){
//code
}
}

(4)生成器函数:用function*定义的函数。

function* foo(){
// code
}

(5)类:用class定义的类,实际上也是函数。

class Foo {
constructor(){
//code
}
}

(6)异步普通函数

async function foo(){
// code
}

(7)异步箭头函数

const foo = async () => {
// code
}

(8)异步生成器函数

async function foo*(){
// code
}

这里主要介绍下箭头函数:

(1)如果箭头函数不需要参数或需要多个参数,可以使用圆括号代表参数部分。

var f=()=>5;

//等同于

var f=function(){return 5 };

var sum=(num1,num2)=>num1+num2;

//等同于

var sum=function(num1,num2)

{

return num1+num2;

}

如果箭头函数的代码块部分多余一条语句,就要使用大括号将其括起来,并使用return语句返回

var sum=(num1,num2)=>
{ let c=num1-45
 return c+num2;
}
(2)由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外面加上括号。
var getObject=id=>({id:id,name:'test'});
console.log(getObject(4))
输出:{id: 4, name: "test"}
 
箭头函数可以与变量解构结合使用
const full=({first,last})=>first+' '+last;
var person={'first':'22','last':'11'}
console.log(full(person))
 
等同于
var person={'first':'22','last':'11'}
function full(person)
{
  return person.first+' '+person.last
}
console.log(full(person))
(3)箭头函数的一个用处是简化回调函数。
console.log([1,2,3].map(function(x)
{
return x*x;
}))
等同于
console.log([1,2,3].map(x=>x*x))
结果为:[1, 4, 9]
 
 
var values=[3,2,6,8]
var result=values.sort(function(a,b)
{
return a-b;
})
console.log(values);
等同于
var result=values.sort((a,b)=>a-b)
console.log(values);
结果为:[2, 3, 6, 8]
 
rest参数和箭头函数结合的例子.
const numbers=(...numbes)=>numbes
console.log(numbers(1,2,3,4,5))
结果为:[1,2,3,4,5]
 
 
const headandTail=(head,...tail)=>{return tail}
console.log(headandTail(1,2,3,4,5))
结果为:[2,3,4,5]
 

Javascript中的几种函数的更多相关文章

  1. 实现一个函数clone,使JavaScript中的5种主要的数据类型(包括Number、String、Object、Array、Boolean)进行值复制

    实现一个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number.String.Object.Array.Boolean)进行值复制. 1 /** 对象克隆 2 * 支持基本 ...

  2. 探究JavaScript中的五种事件处理程序

    探究JavaScript中的五种事件处理程序 我们知道JavaScript与HTML之间的交互是通过事件实现的.事件最早是在IE3和Netscape Navigator 2中出现的,当时是作为分担服务 ...

  3. [转]Javascript中的自执行函数表达式

    [转]Javascript中的自执行函数表达式 本文转载自:http://www.ghugo.com/javascript-auto-run-function/ 以下是正文: Posted on 20 ...

  4. 深入理解javascript中的立即执行函数(function(){…})()

    投稿:junjie 字体:[增加 减小] 类型:转载 时间:2014-06-12 我要评论 这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是 ...

  5. javascript中的立即执行函数(function(){…})()

    javascript中的立即执行函数(function(){…})() 深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){…})()包 ...

  6. 对 JavaScript 中的5种主要的数据类型进行值复制

    定义一个函数 clone(),可以对 JavaScript 中的5种主要的数据类型(包括 Number.String.Object.Array.Boolean)进行值复制 使用 typeof 判断值得 ...

  7. 深入理解javascript中的立即执行函数

    这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){…})()包住业务代码,使用jquery时比较常见,需要的朋友可以 ...

  8. js中的三种函数写法

    js中的三种函数写法 <script type="text/javascript"> //普通的声明方式 function myFun(m,n){ alert(m+n) ...

  9. JavaScript 中的12种循环遍历方法

    原文:JavaScript 中的12种循环遍历方法 题目:请介绍 JavaScript 中有哪些循环和遍历的方法,说说它们的应用场景和优缺点? 1.for 循环 let arr = [1,2,3];f ...

随机推荐

  1. 01-Java类加载机制详解

    类的加载过程 在使用java命令运行主类(main)的时候,首先要通过类加载器将类加载到JVM内存中去.主类在运行过程中如果用到其他的类就会逐步加载这些类.jar包里的类并不是一次性加载的,是使用的时 ...

  2. GO-&获取地址与*解引用

    &变量 获取变量在内存空间的地址 *变量地址 获取变量的值 一.普通数据 package main import "fmt" func main(){ b :=1111 c ...

  3. Kafka与RabbitMQ对比

    Infi-chu: http://www.cnblogs.com/Infi-chu/ Kafka是LinkedIn在2012年发布的开源的消息发布订阅系统,他主要用于处理活跃的流式数据.大数据量的数据 ...

  4. linux脚本判断当前的linux版本是6还是7

    #!/bin/sh version="release 7." release=$(cat /etc/redhat-release) echo $release result=$(e ...

  5. ABP入门教程4 - 初始化运行

    点这里进入ABP入门教程目录 编译解决方案 重新生成解决方案,确保生成成功. 连接数据库 打开JD.CRS.Web.Host / appsettings.json,修改数据库连接设置Connectio ...

  6. Mongodb介绍(非原创)

    文章大纲 一.什么是nosql二.mongodb与mysql比较三.参考文章   一.什么是nosql 1. 简介 这一类数据库主要会使用到一个哈希表,这个表中有一个特定的键和一个指针指向特定的数据. ...

  7. bay——安装_Oracle 12C-RAC-Centos7.txt

    ★★★____★☆★〓〓〓〓→2019年6月26日10:29:42 bayaim-RAC ——搭建第4次VMware vSphere Client6.0 ----------------------- ...

  8. 使用EA将源码转化为类图

    EA简介: EA 全名 Enterprise Architect,是一款著名的 UML 建模软件.在软件架构设计与逆向工程中具有重要作用.软件十分小巧(< 60MB ),并且有汉化破解版.推荐大 ...

  9. private构造器和单例模式

    // hiding/Lunch.java // Demonstrates class access specifiers. Make a class // effectively private wi ...

  10. 普通结果集ResultSet和离线结果集RowSet(四)

    数据库的查询操作会得到一系列数据,JDBC API也提供了相关对象来接收查询结果集. 一.ResultSet java.sql.ResultSet接口表示数据库查询的结果集. JDBC提供以下连接方法 ...