函数——箭头函数&自执行函数(二)
一、箭头函数是在es6中添加的一种规范,它相当于匿名函数,简化了函数的定义。
1、语法
a、function用var,let,cost来表示;
b、参数要写在第一个等号后面;
参数有多个,需要加一个小括号,参数用逗号隔开);只有一个参数时,可以不需要括号;没有参数,写一对空的小括号。
c、函数的主体内容是放在箭头后面
如果主体有多条语句,需要把它们放在一对大括号里;如果主体只有一条语句,那就直接写(如果这条语句里有return,依然需要加上大括号);如果主体只有一条语句,并且是个对象,需要把它用括号括起来。
<script>
//多个参数
const fn = (a, b) => {
let result = a + b;
console.log(result);//3
}
fn(1, 2) //只有一个参数
var fn2 = c => {
console.log(c); //davina
}
fn2('davina'); //没有参数
let fn3 = () => {
console.log('123');
}
fn3(); //123 //函数里只有一句话
const fn4 = d => console.log(d); //lisa
fn4('lisa'); //函数里只有return一句话时
const fn5=()=>{return{a:10,b:20}};
console.log(fn5()); //{a: 10, b: 20}
</script>
2、需要注意的是:
箭头函数只能先定义再使用,箭头函数里没有this对象,函数在哪里定义的,this就指向谁(箭头函数会继承外层函数调用的this绑定);
没有this也就不能调用函数的call,apply,bind方法了;没有this就不是构造函数,不能用new去调用;箭头函数里没有arguments对象。
<script>
const dog = {
color: 'white',
show1: function () {
console.log(this.color);
},
show2: () => {
console.log(this.color);
},
show3: function () {
const show4 = () => {
console.log(this.color);
}
show4();
}
}
dog.show1();//white
dog.show2();//undefined
dog.show3(); //white //不用用call和没有arguments对象
const bigDog =
{
color: 'black'
}
dog.show2.call(bigDog); //undefined const fn6 = () => {
console.log(arguments) // ReferenceError: arguments is not defined
}
fn6(1, 3);
</script>
二、自执行函数:函数被定义后它可以自动执行。
函数表达式可以直接加上小括号调用但函数声明不能直接调用,因为小括号里只能放表达式,不能放语句,function关键字既可以当作语句,也可以当作表达式,但是js规定function关键字出现在行首,一律解释成语句。
<script>
var fn1 = function () {
console.log('这是一个函数表达式'); //这是一个函数表达式
}(); // function fn2(){
// console.log('这是一个函数声明'); //函数声明加上小挌号报错
// }();</script>
解决方法:不让function出现在行首
a. 用括号把function主体括起来,转成表达式,后面加括号
b.借助运算符(new + - ! typeof && || ...)
<script>
//1、加括号
(function fn2() {
console.log('这是一个函数声明'); //这是一个函数声明
})(); (function fn2() { console.log('这是一个函数声明') }());//这是一个函数声明 //两种模式
(function () { })();
(function () { }()); //2、函数变成表达式
0 + function (a) {
console.log(a) //与数字相加变成表达式
}('与数字相加变成表达式') true && function (a) {
console.log(a) //1.利用逻辑运算符变成表达式
}('1.利用逻辑运算符变成表达式') false || function (b) {
console.log(b)
}('2.利用逻辑运算符变成表达式') //2.利用逻辑运算符变成表达式 ~function (c) {
console.log(c)
}('利用+ - !~ 变成表达式') //利用+ - !~ 变成表达式 typeof function (d) {
console.log(d)
}('利用typeof') //利用typeof
</script>
{
let x = 10;
((x) => {
console.log(x); //10
})(x);
}
函数——箭头函数&自执行函数(二)的更多相关文章
- js中的匿名函数和匿名自执行函数
1.匿名函数的常见场景 js中的匿名函数是一种很常见的函数类型,比较常见的场景: <input type="button" value="点击" id ...
- JavaScript闭包函数&箭头函数调用与执行
一.标准的闭包函数 //一.标准的闭包函数 function A() { var i=0; ++i; console.log('i : ' + i); return function b() { re ...
- js中函数表达式和自执行函数表达式的用法总结
立即调用函数表达式 给函数体加大括号,在有变量声明的情形下,没有任何区别 但是,如果只是[自动执行]的情形下,就会不同 因为,一个匿名函数,不赋值或函数体不加小括号,是不能自动执行的 //以下情形并无 ...
- jquery中ready函数,$(function(){})与自执行函数的区别
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- lua 根据函数名字符串来执行函数
function myfunction(msg) print("this is msg fun " .. msg); end local fun =_G["myfunct ...
- 使用"立即执行函数"(Immediately-Invoked Function Expression,IIFE)
一.原始写法 模块就是实现特定功能的一组方法. 只要把不同的函数(以及记录状态的变量)简单地放在一起,就算是一个模块. function m1(){ //... } function m2(){ // ...
- 立即执行函数(IIFE)的理解与运用
作为JavaScript的常用语法,立即执行函数IIFE(Immediately-Invoked Function Expression)是值得我们认真去学习探究的. 一.创建函数的两种方式 我们先从 ...
- JS执行顺序-函数声明提升、匿名函数、函数表达式
大方向上: JS 是按照 代码块 进行 编译.执行 的. 学习至: 1.变量声明提升 2.新唐的博客 3.js中匿名函数的创建与调用方法分析 4.前端圣经 - <高程三> 5.深入理解变量 ...
- 【JavaScript专题】--- 立即执行函数表达式
一 什么是立即执行函数表达式 立即执行函数表达式,其实也可以叫初始化函数表达式,英文名:IIFE,immediately-inovked-function expression.立即执行函数表达式就是 ...
- (译)详解javascript立即执行函数表达式(IIFE)
写在前面 这是一篇译文,原文:Immediately-Invoked Function Expression (IIFE) 原文是一篇很经典的讲解IIFE的文章,很适合收藏.本文虽然是译文,但是直译的 ...
随机推荐
- CentOS7重启后resolv.conf被重置的解决方案
近期在修改一台CentOS7服务器的dns时发现只要重启服务器DNS就会被强制还原,解决方案如下: 1.首先在网卡设置中修改NM_CONTROLLED的值: 修改文件/etc/sysconfig/ne ...
- 04Flutter仿京东商城项目 首页商品列表布局
Home.dart import 'package:flutter/material.dart'; import 'package:flutter_swiper/flutter_swiper.dart ...
- 一百二十九:CMS系统之七牛云存储介绍和配置
将图片的存储.尺寸等图片本身的一些擦做,交给七牛云处理,自己只关注网站开发本身 七牛云官网:https://www.qiniu.com 操作 登录后,点击管理控制台 点击对象存储-->新建存储空 ...
- [Scikit-learn] *2.3 Clustering - DBSCAN: Density-Based Spatial Clustering of Applications with Noise
http://scikit-learn.org/stable/modules/generated/sklearn.cluster.DBSCAN.html#sklearn.cluster.DBSCAN ...
- SQL中有关DQL、DML、DDL、DCL的概念与区别?
SQL(Structure Query Language)结构化查询语言是数据库的核心语言,是高级的非过程化编程语言.它功能强大,效率高,简单易学易维护.SQL语言基本上独立于数据库本身.使用的机器. ...
- 关于RNN(Recurrent Neural Network)的一篇文章
文章链接:https://blog.csdn.net/zhaojc1995/article/details/80572098 写的很好!
- TCP为什么要三次握手?
在<计算机网络>一书中其中有提到,三次握手的目的是“为了防止已经失效的连接请求报文段突然又传到服务端,因而产生错误”,这种情况是: 一端(client)A发出去的第一个连接请求报文并没有丢 ...
- 02.03 win server r2 搭建FTP站点
============ftp服务器搭建=============== 先要搭建iis信息服务: 1.打开服务器管理器,角色>添加角色 2.选择角色服务:应用程序开发.FTP服务器.安全性 3. ...
- spring效验
相关依赖 如果开发普通 Java 程序的的话,你需要可能需要像下面这样依赖: <dependency> <groupId>org.hibernate.validator< ...
- spring使用注解的方式创建bean ,将组件加入容器中
第一种使用@Bean的方式 1.创建一个bean package com.springbean; public class Person { private String name; private ...