【问题标题】:Trying to implement Google's Fast Button尝试实现谷歌的快速按钮
【发布时间】:2011-09-12 02:38:21
【问题描述】:

我正在尝试为移动触摸事件实现 Google 的快速按钮,但我似乎被卡住了。我正在尝试对其进行设置,以便可以将链接链接到快速按钮,但我似乎无法正确设置我的库结构。当我尝试在链接上运行 for 循环时,最终发生的事情是快速按钮重新初始化。

我确定这正是我设置库的方式。有人可以检查一下吗?谢谢!

http://code.google.com/mobile/articles/fast_buttons.html

    ;(function() {
/*Construct the FastButton with a reference to the element and click handler.*/
this.FastButton = function(element, handler) {
    console.log('fastbutton init');
    this.element = element;
    this.handler = handler;
    console.log(this);
    element.addEventListener('touchstart', this, false);
    element.addEventListener('click', this, false);
};

/*acts as an event dispatcher*/
this.FastButton.prototype.handleEvent = function(event) {
    console.log(event);
    switch (event.type) {
        case 'touchstart': this.onTouchStart(event); break;
        case 'touchmove': this.onTouchMove(event); break;
        case 'touchend': this.onClick(event); break;
        case 'click': this.onClick(event); break;
    }
};

/*Save a reference to the touchstart coordinate and start listening to touchmove and
 touchend events. Calling stopPropagation guarantees that other behaviors don’t get a
 chance to handle the same click event. This is executed at the beginning of touch.*/
this.FastButton.prototype.onTouchStart = function(event) {
    event.stopPropagation();
    this.element.addEventListener('touchend', this, false);
    document.body.addEventListener('touchmove', this, false);
    this.startX = event.touches[0].clientX;
    this.startY = event.touches[0].clientY;
};

/*When /if touchmove event is invoked, check if the user has dragged past the threshold of 10px.*/
this.FastButton.prototype.onTouchMove = function(event) {
    if (Math.abs(event.touches[0].clientX - this.startX) > 10 ||
            Math.abs(event.touches[0].clientY - this.startY) > 10) {
        this.reset(); //if he did, then cancel the touch event
    }
};

/*Invoke the actual click handler and prevent ghost clicks if this was a touchend event.*/
this.FastButton.prototype.onClick = function(event) {
    event.stopPropagation();
    this.reset();
    this.handler(event);
    if (event.type == 'touchend') {
        console.log('touchend');
        //clickbuster.preventGhostClick(this.startX, this.startY);
    }
};

this.FastButton.prototype.reset = function() {
    this.element.removeEventListener('touchend', this, false);
    document.body.removeEventListener('touchmove', this, false);
};

this.clickbuster = function() {
    console.log('init clickbuster');
}
/*Call preventGhostClick to bust all click events that happen within 25px of
 the provided x, y coordinates in the next 2.5s.*/
this.clickbuster.preventGhostClick = function(x, y) {
clickbuster.coordinates.push(x, y);
window.setTimeout(this.clickbuster.pop, 2500);
};

this.clickbuster.pop = function() {
this.clickbuster.coordinates.splice(0, 2);
};
/*If we catch a click event inside the given radius and time threshold then we call
 stopPropagation and preventDefault. Calling preventDefault will stop links
 from being activated.*/
this.clickbuster.onClick = function(event) {
for (var i = 0; i < clickbuster.coordinates.length; i += 2) {
 console.log(this);
    var x = clickbuster.coordinates[i];
    var y = clickbuster.coordinates[i + 1];
    if (Math.abs(event.clientX - x) < 25 && Math.abs(event.clientY - y) < 25) {
        event.stopPropagation();
        event.preventDefault();
    }
}
};

})(this);



document.addEventListener('click', clickbuster.onClick, true);
clickbuster.coordinates = [];

【问题讨论】:

  • 感谢您将代码放在一起!我已经把它放在了 GitHub 上,并做了一些小的调整:github.com/alexblack/google-fastbutton
  • 我有一个处理程序在 iOS 上被调用两次的问题:stackoverflow.com/questions/14336001/…
  • 嗨,有没有办法让快速按钮允许同时按下一个以上的按钮,就像用户使用多于一根手指打字的键盘一样。当两次点击重叠时,只会接受第一个输入。

标签: javascript javascript-events mobile-website


【解决方案1】:

尝试用 new 调用构造函数?

new FastButton(el, function() {});

【讨论】:

  • 因为 FastButton 是某个元素 id 的监听器。如何将变量传递给函数。示例 id="fastButton" onclick="doSomething(34)"
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-02-28
  • 2022-12-03
  • 2012-08-13
  • 2015-11-05
  • 2020-02-28
  • 1970-01-01
相关资源
最近更新 更多