首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript 箭头函数不完全指北

在 JavaScript 中,我们通常可以使用如下代码进行函数声明 function example(paramters){ //函数体 } 或者 var example = function...,但是它们本质上完全不同 1.箭头函数不能显式地命名2.箭头函数不能用作构造函数,并且没有 prototype 属性,这意味着不能使用 new 关键字3.箭头函数会绑定到所在的词法作用域,不会改变 this...所以不能在普通函数里面用this来访问对象的属性。在对象内部定义的匿名函数的this指针也是指向window对象,而不是该对象。...console.log(self.param); //world },1000) } } obj.method1() obj.method2() 但是使用箭头函数就完全不会存在这些问题...,由于箭头函数不会创建新的作用域,在箭头函数的函数体内,this、arguments 以及 super 均属于所在的父级作用域。

31920
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    完全搞懂 Javascript 中的...

    曾几何时,ES6/ES2015 对 Javascript 语言进行了重大升级。它引入了许多不同的新功能。其中之一就是我们可以用在任何兼容容器(对象、数组、字符串、集合、映射)前面的三个连续点。...这些小点使我们能够编写更加优雅和简洁的代码。在本文中我将会解释这三个点的工作原理,并展示最常见的例子。...在 ES6 之前,我们必须将该函数应用于 arguments。现在我们可以将参数展开到函数中,从而使代码更简洁。...你可以用索引来访问它,但是不能调用像 map、filter 这样的数组方法。参数是一个可迭代的对象,那么我们做些什么呢?在它们前面放三个点,然后作为数组去访问!...复制的工作方式与数组相同。在以前它可以通过 Object.assign 和一个空的对象常量来实现。

    69120

    36个工作中常用的JavaScript函数片段

    return Math.max(...arr); } 查找数组最小 function arrayMin(arr) { return Math.min(...arr); } 返回已 size 为长度的数组分割的原数组...arr.slice(0, arr.length - n) : []; } 截取第一个符合条件的元素及其以后的元素 function dropElements(arr, fn) { while (arr.length...,且最后也要应用上没有前缀的情况,看最后浏览器起效的何种情况 // 这就是最好在prefix里的最后一个元素是'' prefixValue.forEach((item) => { eleStyle...function preventScroll() { // 存储当前滚动位置 scrollTop = window.scrollY; // 将可滚动区域固定定位,可滚动区域高度为 0 后就不能滚动了...document.documentElement.scrollHeight || document.documentElement.clientHeight) ); } 判断元素是否在可视范围内 partiallyVisible 为是否为完全可见

    47020

    JavaScript 函数作用域和块作用域不完全指北

    我们在 JavaScript 词法作用域不完全指北 中介绍了词法作用域,词法作用域是由你写代码时将变量和块作用域写在哪里来决定的,词法分析器处理代码时会保持作用域不变。...那么究竟什么时候才会生成新的作用域呢?最常见的答案是 JavaScript 具有基于函数的作用域,这意味着每声明一个函数都会为其自身创建一个作用域。...JavaScript 提供了能够同时解决这两个问题的方案。需要注意的是这两种方案使用的都是函数表达式,而不是函数声明。函数声明和函数表达式最重要的区别是它们的名称标识符将会绑定在何处。...匿名函数 函数表达式是可以匿名的,但是函数声明是不可以匿名的(JavaScript 标准不允许)。...参考 •《你不知道的JavaScript》•《深入理解JavaScript特性》

    62710

    jQuery入口函数的写法

    需要引入jQuery文件 入口函数的标准 在 标签中,jQuery入口函数必须要写,在 可以不写,写上入口函数后不论放在哪个标签下都能去执行...一般建议在body标签中写入口函数,就是为了等页面加载完成后才执行入口函数。 案例: js的入口函数执行要比jQuery的入口函数执行得晚一些。...jquery的入口函数会等待页面的加载完成才执行,但是不会等待图片的加载。 js的入口函数会等待页面加载完成,并且等待图片加载完成才开始执行 //js的入口函数执行要比jQuery的入口函数执行得晚一些。...() { console.log("这是jQuery入口函数的第一种写法"); }); $(function () { console.log("这是jQuery入口函数的第二种写法

    1.2K30

    函数表达式在JavaScript中是如何工作的?

    在JavaScript中,函数表达式是一种将函数赋值给变量的方法。函数表达式可以出现在代码的任何位置,而不仅仅是函数声明可以出现的位置。...这意味着myFunction变量现在持有了一个函数作为其值。 函数表达式的工作方式如下: 1:变量声明:使用var、let或const关键字声明一个变量,例如myFunction。...函数表达式的特点: 1:匿名函数:函数表达式可以是匿名函数,即没有函数名。在这种情况下,函数只能通过变量名来调用。...这样的函数在函数内部和外部都可以通过函数名来调用自身。...函数声明会被提升到作用域的顶部,而函数表达式不会被提升。因此,在使用函数表达式之前,需要确保该表达式已经被赋值。此外,函数表达式还可以根据需要在运行时动态创建函数,具有更大的灵活性。

    22050

    还有什么是JavaScript不能做的

    能用JavaScript做的,最后都会用JavaScript来做 不知不觉,JavaScript已经成为一门全栈语言,前端可以使用它,后台还能使用它,哪哪都有它的身影,都说python语言市场占有率极高...网页开发 css,javascript,html作为网页开发三剑客,是每个人都必须要掌握的,而作为web2.0动态交互的主力军,JavaScript受到越来越多的人重视,无数的框架层出不穷,从早期的dojo...,prototype,jquery,到现在的vue,angular,react,人们对于js框架的开发从未停止脚步,我相信未来还会有更多的框架诞生。...丰富的组件,丰富的npm包资源,js的社区和python相比有过之而无不及。 客户端开发 不能开发客户端桌面的语言不是好语言。...总结 看起来似乎没有什么能够阻挡JavaScript的脚步,似乎各个领域都可以使用Javascript来进行开发。然而术业有专攻,最适合JavaScript的依然还是在浏览器这个执行环境中。

    39030

    JavaScript 是如何工作的🔥 🤖

    JavaScript 中的函数与其他编程语言相比,工作方式有所不同。...JavaScript 会在我们运行代码的第一阶段创建一个全局执行上下文并为所有变量和函数分配内存,如下所示。 对于函数,它会将整个函数存储在内存中。...它将获得 num 的值,该值等于第一个变量的 2,然后计算 ans。计算完 ans 后,它将返回将分配给 square2 的值。 一旦函数返回值,它将在完成工作时销毁其执行上下文。...一旦所有代码执行完毕,全局执行上下文也将被销毁,这就是 JavaScript 在幕后执行代码的方式。 调用栈 当在 JavaScript 中调用一个函数时,JavaScript 会创建一个执行上下文。...当我们将函数嵌套在函数中时,执行上下文会变得复杂。 JavaScript 在 Call Stack 的帮助下管理代码执行上下文的创建和删除。

    2.5K10

    JavaScript是如何工作的?

    原文作者:Ganesh Jaiwal 地址:https://dev.to/ganeshjaiwal/how-does-javascript-work-45oc 您是否知道简单的 JavaScript 语句需要大量工作才能完成...内存堆 JavaScript 引擎有时无法在编译时分配内存,因此在运行时分配的变量将进入内存堆(内存的非结构化区域)。即使我们退出在堆中分配内存的函数,我们在堆部分中分配的数据/对象仍然存在。...那么,一次只允许一项任务时,该如何工作? 这是Web API的和回调队列。...1 秒钟后,WebAPI 将得到通知,嘿,您有需要立即执行的代码。 WebAPI “哦,这是 console.log(),我需要执行它,但是我不能直接执行它。...// First // Third // Second 这只是 JavaScript 引擎工作原理的概述。 分享,收藏,点赞,在看支持作者

    2.8K31

    解决Select2控件不能在jQuery UI Dialog中不能搜索的bug

    但是他给出解决的方法,我看不太懂,后面也有人说直接修改jQuery UI类库,但是我们项目中使用的jquery-ui-1.10.3.min.js。...所以不可能修改jQuery UI的源代码,而已修改源代码,在后期类库升级和维护上,各种坑还是比较多。所以我继续搜索解决版本。在jQuery UI的官网找到了方法。...hot fix代码如下: hot fix:Select2控件在jQuery UI弹出对话中不能搜索 $.widget("ui.dialog", $.ui.dialog, { open:...,还需要更深入了解它的工作原理和细节。...这样在遇到不可知的bug时,能快速找到问题的根源是关键。这也是工作之后,leader或者manager更加强调你发现问题和解决问题的能力。

    1.6K100

    10 - JavaScript 中的函数 & 11 - JavaScript 中函数的种类

    原文地址:https://dev.to/bhagatparwinder/functions-in-javascript-5ehm 什么是函数?它在 JavaScript 中扮演什么角色?...函数就是 JavaScript 中可以被执行的代码块。函数有如下必备部分: 1. 使用 function 关键字声明; 2. 函数名字紧跟其后,它就是被调用时使用的名字。 3....JavaScript 自带的函数 你不是要经常写函数,JavaScript 自带了许多可以直接使用的方法。...函数声明在其他代码执行之前被加载,然而函数表达式只有等到 JavaScript 解释器执行到所在代码行时才被加载。这就是 JavaScript 中 hoisting[1] 的原理。...; console.log(hello()); // Hello World 我们移出了 return 关键字,当我们只有一条语句且该语句返回一个值时,这样完全是可以的。 箭头函数同样可以接受参数。

    2.8K20

    JavaScript的构造函数

    在Java语言中,我们使用构造函数是实例化对象的过程,在JavaScript语言中我们可以使用构造函数的方式创建对象,如: let obj = new LanguageFun("javaScript")...与面向对象的语言不同,JavaScript使用构造函数创建对象不是真正意义上的实例化,而是通过new操作符调用的构造函数。...构造函数的执行过程: 1. 创建一个新的对象obj 2. obj被执行原型链[[prototype]]连接 3. obj绑定到函数调用的this上 4....没有其他返回对象,则返回obj 包括我们知道的内置函数Number(), String()都可以使用new操作符创建新的对象,这种函数在JavaScript中称为构造函数的调用。...,产生异常,所以我们需要对JavaScript的构造函数进行兼容改造。

    1K70

    JavaScript 函数的定义

    一、关于函数 JavaScript函数是指一个特定代码块,可能包含多条语句,可以通过名字来供其他语句调用以执行函数包含的代码语句。 比如我们有一个特定的功能需要三条语句实现 ?...2.1 规则 (1)函数声明只能出现在 程序或函数体内。从句法上讲,它们不能出现在 Block(块)({ ... })中,例如不能出现在 if、while 或 for 语句中。...因为 Block(块)中只能包含Statement语句, 而不能包含函数声明这样的源元素。...这叫做函数的声明(Function Declaration)。 3.2 注意 (1)JavaScript 对大小写敏感。...第一次是解析常规javascript代码,第二次解析传入构造函数中的字符串,影响性能。 ? 阅读更多 参考文章 深入理解JavaScript系列(2):揭秘命名函数表达式

    1.1K30
    领券