JS易错点总结与解决

这次给大家带来JS易错点总结与解决,解决JS易错点的注意事项有哪些,下面就是实战案例,一起来看一下。

1.前言

这段时间,金三银四,很多人面试,很多人分享面试题。在前段时间,我也临时担任面试官,为了大概了解面试者的水平,我也写了一份题目,面试了几个前端开发者。在这段时间里面,我在学,在写设计模式的一些知识,想不到的设计模式的这些知识,就是面试题里面,频繁让人掉坑的考点。

所以,今天就总结一下,那些让人掉坑的考点。下面话不多说了,来一起看看详细的介绍吧。

2.面向对象编程

关于面向对象和面向过程,个人觉得这两者不是绝对独立的,而是相互相成的关系。至于什么时候用面向对象,什么时候用面向过程,具体情况,具体分析。

针对于面向对象编程的。知乎上有一个高赞回答:

面向对象: 狗.吃(屎)

面向过程: 吃.(狗,屎)

但是这个例子觉得不太优雅,我改一下了,举一个优雅些的小例子说明一下面向对象和面向过程的区别。

需求:定义‘守候吃火锅’

面向对象的思想是:守候.动作(吃火锅)

面向过程的思想是:动作(守候,吃火锅)

代码实现方面:

//面向对象//定义人(姓名)let People=function(name){ this.name=name;}//动作People.prototype={ eat:function(someThing){ console.log(`${this.name}吃${someThing}`); }}//守候是个人,所以要创建一个人(new一次People)let shouhou=new People('守候','男',24);shouhou.eat('火锅');//面向过程let eat=function(who,someThing){ console.log(`${who}吃${someThing}`);}eat('守候','火锅');

登录后复制

结果都一样,都是输出‘守候吃火锅’。但是万一我现在吃饱了,准备写代码了。这下怎么实现呢?看代码

//面向对象shouhou.coding=function(){ console.log(this.name+'写代码');}shouhou.coding();//面向过程let coding=function(who){ console.log(who+'写代码');}coding('守候');

登录后复制

结果也一样:‘守候写代码’

但是不难发现面向对象更加的灵活,复用性和扩展性更加。因为面向对象就是针对对象(例子中的:‘守候’)来进行执行某些动作。这些动作可以自定义扩展。

而面向过程是定义很多的动作,来指定谁来执行这个动作。

好了,面向对象的简单说明就到这里了,至于面向对象的三大特性:继承,封装,多态这个自行上网查找资料。

3.this

使用 JavaScript 开发的时候,很多开发者多多少少会被 this 的指向搞蒙圈,但是实际上,关于 this 的指向,记住最核心的一句话:哪个对象调用函数,函数里面的this指向哪个对象。

下面分几种情况谈论下

3-1.普通函数调用

这个情况没特殊意外,就是指向全局对象-window。

let username='守候'function fn(){ alert(this.username);//undefined}fn();

登录后复制

可能大家会困惑,为什么不是输出守候,但是在细看一看,我声明的方式是let,不会是window对象

如果输出守候,要这样写

var username='守候'function fn(){ alert(this.username);//守候}fn();//---------------window.username='守候'function fn(){ alert(this.username);//守候}fn();

登录后复制

3-2.对象函数调用

这个相信不难理解,就是那个函数调用,this指向哪里

window.b=2222let obj={ a:111, fn:function(){ alert(this.a);//111 alert(this.b);//undefined }}obj.fn();

登录后复制

很明显,第一次就是输出obj.a,就是111。而第二次,obj没有b这个属性,所以输出undefined,因为this指向obj。

但是下面这个情况得注意

let obj1={ a:222};let obj2={ a:111, fn:function(){ alert(this.a); }}obj1.fn=obj2.fn;obj1.fn();//222

登录后复制

这个相信也不难理解,虽然obj1.fn是从obj2.fn赋值而来,但是调用函数的是obj1,所以this指向obj1。

3-3.构造函数调用

let TestClass=function(){ this.name='111';}let subClass=new TestClass();subClass.name='守候';console.log(subClass.name);//守候let subClass1=new TestClass();console.log(subClass1.name)//111

登录后复制

这个也是不难理解,回忆下(new的四个步骤)就差不多了!

但是有一个坑,虽然一般不会出现,但是有必要提一下。

在构造函数里面返回一个对象,会直接返回这个对象,而不是执行构造函数后创建的对象

JS易错点总结与解决

3-4.apply和call调用

apply和call简单来说就是会改变传入函数的this。

let obj1={ a:222};let obj2={ a:111, fn:function(){  alert(this.a); }}obj2.fn.call(obj1);

登录后复制登录后复制

此时虽然是 obj2 调用方法,但是使用 了call,动态的把 this 指向到 obj1。相当于这个 obj2.fn 这个执行环境是 obj1 。apply 和 call 详细内容在下面提及。

3-5.箭头函数调用

首先不得不说,ES6 提供了箭头函数,增加了我们的开发效率,但是在箭头函数里面,没有 this ,箭头函数里面的 this 是继承外面的环境。

一个例子

let obj={ a:222, fn:function(){   setTimeout(function(){console.log(this.a)}) }};obj.fn();//undefined

登录后复制

不难发现,虽然 fn() 里面的 this 是指向 obj ,但是,传给 setTimeout 的是普通函数, this 指向是 window , window 下面没有 a ,所以这里输出 undefined 。

换成箭头函数

let obj={ a:222, fn:function(){   setTimeout(()=>{console.log(this.a)}); }};obj.fn();//222

登录后复制

这次输出 222 是因为,传给 setTimeout 的是箭头函数,然后箭头函数里面没有 this ,所以要向上层作用域查找,在这个例子上, setTimeout 的上层作用域是 fn。而 fn 里面的 this 指向 obj ,所以 setTimeout 里面的箭头函数的 this ,指向 obj 。所以输出 222 。

4.call和apply

call 和 apply 的作用,完全一样,唯一的区别就是在参数上面。

call 接收的参数不固定,第一个参数是函数体内 this 的指向,第二个参数以下是依次传入的参数。

apply接收两个参数,第一个参数也是函数体内 this 的指向。第二个参数是一个集合对象(数组或者类数组)

let fn=function(a,b,c){console.log(a,b,c);}let arr=[1,2,3];

登录后复制

JS易错点总结与解决

如上面这个例子

let obj1={ a:222};let obj2={ a:111, fn:function(){  alert(this.a); }}obj2.fn.call(obj1);

登录后复制登录后复制

call 和 apply 两个主要用途就是

1.改变 this 的指向(把 this 从 obj2 指向到 obj1 )

2.方法借用( obj1 没有 fn ,只是借用 obj2 方法)

5.闭包

闭包这个可能大家是迷糊,但是必须要征服的概念!下面用一个例子简单说下

let add=(function(){let now=0;return { doAdd:function(){ now++; console.log(now);}}})()

登录后复制

然后执行几次!

JS易错点总结与解决

上图结果看到,now 这个变量,并没有随着函数的执行完毕而被回收,而是继续保存在内存里面。

具体原因说下:刚开始进来,因为是自动执行函数,一开始进来会自动执行,这一块

JS易错点总结与解决

然后把这个对象赋值给 add 。由于 add 里面有函数是依赖于 now 这个变量。所以 now 不会被销毁,回收。这就是闭包的用途之一(延续变量周期)。由于 now 在外面访问不到,这就是闭包的另一个用途(创建局部变量,保护局部变量不会被访问和修改)。

可能有人会有疑问,闭包会造成内存泄漏。但是大家想下,上面的例子,如果不用闭包,就要用全局变量。把变量放在闭包里面和放在全局变量里面,影响是一致的。使用闭包又可以减少全局变量,所以上面的例子闭包更好!

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

vue做出全选与反选功能

Vue中如何实现Observer

vue.js element-ui tree树形控件如何修改iview

以上就是JS易错点总结与解决的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2763929.html

(0)
上一篇 2025年3月8日 10:21:51
下一篇 2025年3月8日 10:22:02

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JS里new()使用技巧

    这次给大家带来JS里new()使用技巧,JS里new()使用的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中…

    2025年3月8日
    200
  • $http方法传递json参数步骤详解

    这次给大家带来$http方法传递json参数步骤详解,$http方法传递json参数的注意事项有哪些,下面就是实战案例,一起来看一下。 具体如下: 一、$http POST方法默认提交数据的类型为application/json var d…

    2025年3月8日
    200
  • JS获取url参数并发送Json格式POST请求案例详解

    这次给大家带来JS获取url参数并发送Json格式POST请求案例详解,JS获取url参数并发送Json格式POST请求的注意事项有哪些,下面就是实战案例,一起来看一下。 登录后复制 一、获取url所有参数值 function US() {…

    编程技术 2025年3月8日
    200
  • js传递json参数到controller步骤详解

    这次给大家带来js传递json参数到controller步骤详解,js传递json参数到controller的注意事项有哪些,下面就是实战案例,一起来看一下。 Spring MVC在接收集合请求参数时,需要在Controller方法的集合参…

    编程技术 2025年3月8日
    200
  • Vue.js实现可配置登录表单步骤详解

    这次给大家带来Vue.js实现可配置登录表单步骤详解,Vue.js实现可配置登录表单的注意事项有哪些,下面就是实战案例,一起来看一下。 业务场景 在之前,项目只支持手机号+密码登录,前端是直接把表单写死的,后来有客户希望能支持验证码登录,有…

    2025年3月8日
    200
  • 怎样用JS验证E-mail格式

    这次给大家带来怎样用JS验证E-mail格式,用JS验证E-mail格式的注意事项有哪些,下面就是实战案例,一起来看一下。 最近做了一个前端的项目,要求:输入的数据必须包含 @ 符号和点号(.)。同时,@ 不可以是邮件地址的首字符,并且 @…

    2025年3月8日
    200
  • JS如何优化分时函数

    这次给大家带来JS如何优化分时函数,JS优化分时函数的注意事项有哪些,下面就是实战案例,一起来看一下。 函数节流的原理是:延迟当前函数的执行,如果该次延迟还没有完成,那么忽略接下来该函数的请求。也就是说会忽略掉很多函数请求。 在一些开发场景…

    编程技术 2025年3月8日
    200
  • JS实现左右列表互相调换功能

    这次给大家带来JS实现左右列表互相调换功能,JS实现左右列表互相调换的注意事项有哪些,下面就是实战案例,一起来看一下。 实现功能: 1.左边的下拉框内容添加到右边的下拉框,支持多选移动,且同时将右边的下拉框对象移除; 2.支持列表中项目上下…

    2025年3月8日
    200
  • js获取ModelAndView需要哪些步骤

    这次给大家带来js获取ModelAndView需要哪些步骤,js获取ModelAndView的注意事项有哪些,下面就是实战案例,一起来看一下。 1 方法一 【有效】 可以的,跟el表达式访问方式一样。 示例代码,一个数据展示请求的Actio…

    编程技术 2025年3月8日
    200
  • React高阶组件使用技巧总结

    这次给大家带来React高阶组件使用技巧总结,React高阶组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 前段时间在工作中写Hybrid页面时遇到了这样的一个场景,公司需要一系列的活动组件,在每个组件注册的时候都需要调用App…

    2025年3月8日
    200

发表回复

登录后才能评论