IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【ES6】箭头函数 -> 正文阅读

[JavaScript知识库]【ES6】箭头函数

(1)箭头函数的定义

基本语法

        //ES5的函数语法
        //定义式
        let fn=function(){
            console.log(11);
        }
        fn()//11
        //声明
        function fn1(){
            console.log(222);
        };
        fn1()//222
        //ES6箭头函数
        let fn2=()=>{//简单明了,没有function开头了使用"=>"代替
            console.log(3333);
        };
        fn2();//3333

箭头函数只有一个参数时,可以不用括号()

        let fn=a=>{//接受了一个实参,括号可以取消
            console.log(a);
        };
        fn(6)//6

相反,如果使用多个参数,就必须使用括号()

        let fn1=(a,b,c)=>{//接受多个参数需要添加括号,不然会报错,代码不会运行
            console.log(a,b,c);
        };
        fn1(10,20,30);//10 20 30

如果箭头函数的执行体只有一个表达式 就是返回值 那么可以省略大括号。

        let fn=(a,b)=>a+b;
        let num= fn(10,20);
        console.log(num);//30

当箭头函数要返回对象的时候,为了区分于代码块,要用 () 将对象包裹起来。

        let f = (a, b) => ({ id: a, name: b });
        let obj = f(11, "小明");  
        console.log(obj);//{id: 11, name: '小明'}

箭头函数里面的this不是箭头函数的调用者,而是箭头函数的外层作用域。

        let fn=(a,b)=>{
            console.log(this);//此时的 this 是外层的 this 对象,即 Window 
            return a+b
        };
        let obj={name:"小明",fn}
         let num=obj.fn(10,20); //这里按理说fn被调用,函数里面的this就该指向obj,结果却不是
         console.log(num);//30
        //而使用普通函数则是指向的obj
        let fn1=function(a,b){
            console.log(this);//obj
            return a+b
        };
        let obj1={name:"小明",fn}
         let num1=obj.fn(10,20);
         console.log(num);//30

箭头函数不可以作为构造函数,也就是不能使用 new 命令,否则会报错

        let fn=function(){
             console.log(this);
        };
        new fn();//fn {}
        //使用箭头函数会报错
        let fn1=()=>{
            console.log(this);
        };
        new fn1()//报错

(2)使用箭头函数的注意点

(1)箭头函数没有自己的this对象。
(2)不可以当作构造函数,也就是说,不可以对箭头函数使用new命令,否则会抛出一个错误。
(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。
(4)对象里面的方法,尽可能不要使用箭头函数
(5)箭头函数里面的this总是指向最靠近的function 内部的this

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-17 16:13:50  更:2022-07-17 16:18:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 13:19:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码