a v-tap directive of vue.js
- ES6
# install v-tap
npm install v-tap --save;
# 请注意!是**v-tap** 不是 **vue-tap**
import vueTap from 'v-tap';
Vue.use(vueTap);
- 直接引入
<script src="./vue.js"></script>
<script src="./vue-tap.js"></script>
Vue2.0的绑定形式略有不同 主要改为
v-tap={ methods : xxx , paramA : a,paramB:b}
的形式
// 具体请看demo test-href.html
<!--如果想要快速跳转直接写v-tap即可不用写任何参数-->
<a href="http://www.baidu.com" v-tap>如果想要快速跳转直接写v-tap即可不用写任何参数</a>
<p v-tap.prevent="{ methods : scroll }">无法滑动页面</p>
<!-- 这样的a标签可以进行一些处理而不跳转 -->
<a v-tap.prevent="{ methods : cant }" href="这是无法跳转的">这是无法跳转的</a>
<!--这样一样会直接快速跳转不会执行cant 除非设置了prevent-->
<a href="aaa" v-tap="{ methods : cant }">can't</a>
<a v-tap="a++">v-tap="a++" 直接执行表达式在2.0里无法使用</a>
<a href="javascript:window.history.go(-1);" v-tap>我可以直接在href里写js代码 如history.go(-1)</a>
new Vue({
el: "body",
methods : {
callback : function(params) {
// params 可获取绑定时候带的参数
console.log(params.event); // 原生事件
console.log(params.tapObj); // 手指触摸的一些参数
console.log(params.paramA); // 绑定时候传入的paramA
console.log(params.paramB); // 绑定时候传入的paramB
}
}
});
<ul>
<li v-for="(item,index) in list"
v-tap="{ methods:args , index : index, item:item }"
>
{{item.name}}---{{item.age}}
</li>
</ul>
args : function(params) {
// v-for循环带参数的回调
console.log('---params.event---',params.event)
console.log('---params.tapObj---',params.tapObj);
console.log('---params.index---',params.index)
console.log('---params.el---',params.el)
//params.tapObj 可获得 tap的一些参数
//pageX,pageY,clientX,clientY,distanceX,distanceY
//后面2个分别的手指可能移动的位置(以后可用于拓展手势)
},
// 具体请看demo test-href.html
<!--如果想要快速跳转直接写v-tap即可不用写任何参数-->
<a href="http://www.baidu.com" v-tap>如果想要快速跳转直接写v-tap即可不用写任何参数</a>
<p v-tap.prevent="scroll">无法滑动页面</p>
<!-- 这样的a标签可以进行一些处理而不跳转 -->
<a v-tap.prevent="callback" href="这是无法跳转的">这是无法跳转的</a>
<!--这样一样会直接快速跳转不会执行cant 除非设置了prevent-->
<a href="aaa" v-tap="cant">can't</a>
new Vue({
el: "body",
methods : {
callback : function(e) {
//不带参数指令,e为event对象
e.preventDefault();
console.log('---e---',e);
console.log('---tapObj---', e.tapObj);
}
}
});
<ul>
<li v-for="el in list"
v-tap="args($index,el,$event)"
>
{{el.name}}---{{el.age}}
</li>
</ul>
args : function(index,el,e) {
// v-for循环带参数的回调
console.log('---index---',index);
console.log('---el---',el);
console.log('---e---',e);
console.log(e.tapObj);
//e.tapObj 可获得 tap的一些参数
//pageX,pageY,clientX,clientY,distanceX,distanceY
//后面2个分别的手指可能移动的位置(以后可用于拓展手势)
}
支持Vue2.0,兼容Vue1.0
- 修复了PC端的bug
- test-href.html页面,新增测试
- 我是测试v-tap="a++"直接执行表达式 我是history.go(-1)
- 发布npm, 各位可用
npm i v-tap --save;
下载使用- 重写了currentTarget对象,避免currentTarget为null的情况
- fix : 判断el是否为a标签,避免获取href出错
- 经测试没有点透问题
- 统一为v-tap,兼容
PC
和移动端
- 新增捕获a标签的href地址,点击a标签可实现快速跳转
- 解决部分手机点击没有反应的问题
- 准备加入npm大家庭
- 新增 dom带有disable属性时,tap失效
- 新增vue-tap-click版本兼容PC和移动端,v-tap指令将自动判断使用click还是tap事件
- vue-tap 是不带兼容版本, vue-tap-click兼容版本, 请客官自行选择进食.