Jigsaw.prototype.down = function(ev) {
ev.preventDefault();
var oEvent = this.isTouch(ev);
this.flag = true
this.op = $(this);//问题所在
this.op.css('zIndex', 1)
var opOffsetleft = this.op.offset().left;
var opOffsettop = this.op.offset().top;
this.boxX = oEvent.clientX - opOffsetleft; // 鼠标到被选p的横距离
this.boxY = oEvent.clientY - opOffsettop; // 鼠标到被选p的纵距离
this.oriboxLeft = this.op.position().left
this.oriboxTop = this.op.position().top
};
在Jigsaw构造函数的原型上,建立一个鼠标按下事件程序,$(this)中的this应该指向的是被操作的p元素,然而this冲突了,请问如何修改这种情况?
我尝试用ev.target,但是显示的是img元素,本意是想操作p.box的,html代码如下:
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
另外我用jquery,所以希望最后取到p.box的jq对象
Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
this冲突的原因就是点击事件的监听函数this.down执行的时候,函数中的this被改写为DOM对象了,这样本来属于原型对象的this就失效了,解决的方法是在执行this.down的时候绑定原型的作用域,也就是使用this.down.bind(this),这样监听函数里面的this就是原型本身了,但是我们可能还要使用DOM本身的对象,那就可以使用event.target,这个就是被点击对象本身了,如果使用jquery直接$(event.target)就可以了这里的this指向的是Jigsaw实例,不是被操作的元素
可以用
ev.target吧。