函数——箭头函数&自执行函数(二)
一、箭头函数是在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的文章,很适合收藏.本文虽然是译文,但是直译的 ...
随机推荐
- Git Command之Code Review
原文链接 准备 Step 1. Create a team and add a teammate Step 2. Create a repository with some content 应用 Cl ...
- 阶段5 3.微服务项目【学成在线】_day05 消息中间件RabbitMQ_16.RabbitMQ研究-与springboot整合-生产者代码
springBoot给我们提供了 RarbbitTemplate发送消息 创建测试类,因为我们是基于SpringBoot的来写的测试类.所以要加上@SpringBootTest和@RunWith的注解 ...
- 阶段5 3.微服务项目【学成在线】_day02 CMS前端开发_09-webpack研究-webpack介绍
使用vue.js开发大型应用需要使用webpack打包工具,本节研究webpack的使用方法. 1.3.1 webpack介绍 Webpack 是一个前端资源的打包工具,它可以将js.image.cs ...
- kubernetes监控(12)
一.Weave Scope 1. weave scope 容器地图 创建 Kubernetes 集群并部署容器化应用只是第一步.一旦集群运行起来,我们需要确保一起正常,所有必要组件就位并各司其职,有足 ...
- Linux下的命令,删除文件夹下的所有文件,而不删除文件夹本身
Linux下的命令,删除文件夹下的所有文件,而不删除文件夹本身 rm -rf *
- 如何不让Excel图表随源数据改变而改变
如何不让Excel图表随源数据改变而改变 一般我们在用Excel时,经常会碰到一些问题,比如,如何才能不让Excel图表随源数据改变而改变呢,下面就谈一下,一般在默认情况下,Excel的图表在一个区域 ...
- Mysql使用Java UUID作为唯一值时使用前缀索引测试
Mysql可以使用字符串前缀 作为索引 以节约空间. 下面我们以 Java的UUID 生成的 32位(移除UUID中的 中划线)字符串 来做一下 测试. 表结构: CREATE TABLE `test ...
- 值得学习的C语言开源项目和库
收集一些C/C++相关的源码,如有更高效的库,请提醒我 补充上去 C/C++相关交流Q群 1414577 - 1. Webbench Webbench是一个在linux下使用的非常简单的网站压测工具. ...
- windows配置apache支持https
https://my.oschina.net/ososchina/blog/510065
- Linux下运行《UNIX环境高级编程》undefined reference to `err_quit 编译出错的处理方法
错误信息: : undefined reference to `err_quit': undefined reference to `err_sys' 解决方法: 因为err_quit跟err_sys ...