前两天做了个tap.js插件,实现了移动端touch事件模拟click事件,解决点击延迟的问题,但是在vue中并不能用v-tap来调用,所以今天做了vue版的vue-tap.js。此前也曾用过其他的插件来实现v-tap,但方式仍有些累赘,于是便用了更简洁的方式来实现,下面附上代码(只支持vue2.0+)。
vue-tap.js
/*!
* vue-tap.js
* by weijianhua https://github.com/weijhfly/vue-tap
*/
;(function (factory) {
if (typeof define === 'function' && define.amd) {
define(function(){return factory;});
}else if (typeof exports == "object") {
module.exports = factory;
}else{
Vue.use(factory);
}
}({
master:{
bind: function (el, binding) {
var isTouch = "ontouchend" in document;
el.exec = function (e) {
var data = binding.value;
data[0].apply(this, data.slice(1));
};
if (isTouch) {
//touchstart
el.addEventListener('touchstart', function (e) {
binding.modifiers.stop && (e