1.前言:
刚刚学习了js面向对象,打算写个图片轮播的插件,想实现的功能:①新建一个实例,设置对应的属性,就会出现一个图片轮播(已实现);②新建两个实例,就出现互不干扰的两个图片轮播(未实现)。
2.问题以及尝试:
问题:新建了第二个实例之后,第一个实例能生成元素,但是它的动画功能、自动播放功能、鼠标时间都指向了第二个实例,所有计时器都叠加到第二个实例中。

追踪:发现在新建第二个实例后,prototype中的this指向了新的实例

尝试:(请结合我的代码),直接抛弃掉prototype,把所有代码都放进构造函数里面,但是情况还是一样,console.log出来的还是一样。
3.请教:
请问为什么会导致这样,可以提供一些思考的方向吗?我在面向对象方面想不出什么。或者有哪位可以解决这个问题?
4.我的代码:
原生js面向对象封装版图片轮播
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
几个网友解决了我的问题:
把_this=this改为var _this=this
在写这段的时候想起this会变化,就是没有注意到加var,就是说_this是全局变量了。