Android 检测 TouchStart 在原型 JS 上
android detect touchstart on prototype js
我正在尝试使Magento扩展在Android移动设备上工作。我买了这个扩展:
http://ecommerce.aheadworks.com/magento-extensions/layered-navigation.html
获取 Ajax 分层导航。它运行良好,但是当涉及到android兼容性时,我在范围选择器(滑块选择器,用于价格范围)上遇到了问题。
该功能在所有设备(包括ios)上运行良好,但在Android上,我总是在范围选择器上获得NaN而不是数字值。挖掘插件的代码后,我在javascript中找到了起源:
startDrag: function(event) {
var isLeftClick = Event.isLeftClick(event);
if (Prototype.Browser.IE) {
var ieVersion = parseInt(navigator.userAgent.substring(navigator.userAgent.indexOf("MSIE")+5));
if (ieVersion > 8) {
isLeftClick = event.which === 1;
}
}
if (isLeftClick || event.type === 'touchstart') {
if (!this.disabled){
this.active = true;
var handle = Event.element(event);
var pointer = [Event.pointerX(event), Event.pointerY(event)];
var track = handle;
if (track==this.track) {
var offsets = Position.cumulativeOffset(this.track);
this.event = event;
this.setValue(this.translateToValue(
(this.isVertical() ? pointer[1]-offsets[1] : pointer[0]-offsets[0])-(this.handleLength/2)
));
var offsets = Position.cumulativeOffset(this.activeHandle);
this.offsetX = (pointer[0] - offsets[0]);
this.offsetY = (pointer[1] - offsets[1]);
} else {
// find the handle (prevents issues with Safari)
while((this.handles.indexOf(handle) == -1) && handle.parentNode)
handle = handle.parentNode;
if (this.handles.indexOf(handle)!=-1) {
this.activeHandle = handle;
this.activeHandleIdx = this.handles.indexOf(this.activeHandle);
this.updateStyles();
var offsets = Position.cumulativeOffset(this.activeHandle);
this.offsetX = (pointer[0] - offsets[0]);
this.offsetY = (pointer[1] - offsets[1]);
}
}
}
Event.stop(event);
}
}
这一行:
var pointer = [Event.pointerX(event), Event.pointerY(event)];
在所有设备上返回正确的值数组(鼠标坐标),除了在 Android 上,我在那里得到 NaN。这是原型.js的已知错误吗,我可以绕过它吗?
谢谢
通过挖掘事件对象,然后手动检索 X 和 Y pos(测试的客户端 X、screenX 和 pageX)解决了问题:
var pointer = [Event.pointerX(event), Event.pointerY(event)];
if(navigator.userAgent.match(/Android/i)){
pointer = [parseInt(event.targetTouches[0].clientX),parseInt(event.targetTouches[0].clientY)];
}
我遇到了同样的问题,我知道这是一个旧线程,但无论如何都想发布我的解决方案。我需要覆盖刷卡.js中的功能。
update: function(event) {
if (this.active) {
if (!this.dragging) this.dragging = true;
this.draw(event);
if (Prototype.Browser.WebKit) window.scrollBy(0,0);
Event.stop(event);
}
},
draw: function(event) {
var pointer = [Event.pointerX(event), Event.pointerY(event)];
if(navigator.userAgent.match(/Android/i)){
pointer = [parseInt(event.targetTouches[0].clientX),parseInt(event.targetTouches[0].clientY)];
}
var offsets = Position.cumulativeOffset(this.track);
pointer[0] -= this.offsetX + offsets[0];
pointer[1] -= this.offsetY + offsets[1];
this.event = event;
this.setValue(this.translateToValue( this.isVertical() ? pointer[1] : pointer[0] ));
if (this.initialized && this.options.onSlide)
this.options.onSlide(this.values.length>1 ? this.values : this.value, this);
},
这解决了我的问题
相关文章:
- 如何在Mocha/Chai中测试JS原型(非模块)
- 如何从构造函数中调用js原型方法
- 当对象从服务器发送到客户端时,JS原型方法消失了
- JS原型无法设置属性'moveRight'的未定义
- 编写JS原型时,所有函数都应该使用原型对象
- js原型表创建
- JS原型:未捕获的类型错误未定义不是一个函数
- JS:原型模式兼容性
- JS原型 ─为什么是“未定义”
- JS原型是否可以访问初始化期间传递给对象的参数
- JS原型继承的意外结果
- 使用 JS 原型构建大型 JS 应用程序的性能优势
- JS原型,小混乱
- 节点.js原型继承
- JS.原型怪异行为中的属性
- 具有私有方法的JS原型类不访问属性
- JS原型类并非所有属性都可访问
- JS:原型-访问正确的实例属性
- node.js原型定义函数中可访问的私有变量
- node-js原型对象'self'var没有为回调存储正确的上下文