自定义vue指令,滑动

将下面js 放在main.js引入
import touch from '@/assets/js/touch'//触屏滑动
Vue.use(touch);

使用
<div v-swiperight="swiperight">
...
</div>

swiperight为methods里的方法,不能传参,传参会报错

export default {
    install(Vue){
        function vueTouch(el,binding,type){//触屏函数
            var _this=this;
            _this.obj=el;
            _this.binding=binding;
            _this.touchType=type;
            _this.vueTouches={x:0,y:0};//触屏坐标
            _this.vueMoves=true;
            _this.vueLeave=true;
            _this.vueCallBack=typeof(binding.value)=="object"?binding.value.fn:binding.value;
            _this.obj.addEventListener("touchstart",function(e){
                _this.start(e);
            },false);
            _this.obj.addEventListener("touchend",function(e){
                _this.end(e);
            },false);
            _this.obj.addEventListener("touchmove",function(e){
                _this.move(e);
            },false);
        };
        vueTouch.prototype={
            start:function(e){//监听touchstart事件
                this.vueMoves=true;
                this.vueLeave=true;
                this.longTouch=true;
                this.vueTouches={x:e.changedTouches[0].pageX,y:e.changedTouches[0].pageY};
                this.time=setTimeout(function(){
                    if(this.vueLeave&&this.vueMoves){
                        this.touchType=="longtap"&&this.vueCallBack(this.binding.value,e);
                        this.longTouch=false;
                    };
                }.bind(this),1000);
            },
            end:function(e){//监听touchend事件
                var disX=e.changedTouches[0].pageX-this.vueTouches.x;//计算移动的位移差
                var disY=e.changedTouches[0].pageY-this.vueTouches.y;
                clearTimeout(this.time);
                if(Math.abs(disX)>10||Math.abs(disY)>100){//当横向位移大于10,纵向位移大于100,则判定为滑动事件
                    this.touchType=="swipe"&&this.vueCallBack(this.binding.value,e);//若为滑动事件则返回
                    if(Math.abs(disX)>Math.abs(disY)){//判断是横向滑动还是纵向滑动
                        if(disX>10){
                            this.touchType=="swiperight"&&this.vueCallBack(this.binding.value,e);//右滑
                        };
                        if(disX<-10){
                            this.touchType=="swipeleft"&&this.vueCallBack(this.binding.value,e);//左滑
                        };
                    }else{
                        if(disY>10){
                            this.touchType=="swipedown"&&this.vueCallBack(this.binding.value,e);//下滑
                        };
                        if(disY<-10){
                            this.touchType=="swipeup"&&this.vueCallBack(this.binding.value,e);//上滑
                        };  
                    };
                }else{
                    if(this.longTouch&&this.vueMoves){
                        this.touchType=="tap"&&this.vueCallBack(this.binding.value,e);
                        this.vueLeave=false
                    };
                };
            },
            move:function(e){//监听touchmove事件
                this.vueMoves=false;
            }
        };
        Vue.directive("tap",{//点击事件
            bind:function(el,binding){
                new vueTouch(el,binding,"tap");
            }
        });
        Vue.directive("swipe",{//滑动事件
            bind:function(el,binding){
                new vueTouch(el,binding,"swipe");
            }
        });
        Vue.directive("swipeleft",{//左滑事件
            bind:function(el,binding){
                new vueTouch(el,binding,"swipeleft");
            }
        });
        Vue.directive("swiperight",{//右滑事件
            bind:function(el,binding){
                new vueTouch(el,binding,"swiperight");
            }
        });
        Vue.directive("swipedown",{//下滑事件
            bind:function(el,binding){
                new vueTouch(el,binding,"swipedown");
            }
        });
        Vue.directive("swipeup",{//上滑事件
            bind:function(el,binding){
                new vueTouch(el,binding,"swipeup");
            }
        });
        Vue.directive("longtap",{//长按事件
            bind:function(el,binding){
                new vueTouch(el,binding,"longtap");
            }
        });
    }
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • 33、JS中的本地存储 把一些信息存储在当前浏览器指定域下的某一个地方(存储到物理硬盘中)1、不能跨浏览器传输:在...
    萌妹撒阅读 2,067评论 0 2
  • Vue-Music 一| 前期工作 1.项目初始化 npm install -g vue-cli vue init...
    noobakong阅读 1,818评论 0 5
  • vue去哪网跟学笔记 记录学习点滴 1. 初始化项目 1.1 手机显示配适 minimum-scale=1.0,m...
    noobakong阅读 2,225评论 0 16
  • vue-cli搭建项目 确保安装了node与npm 再目标文件夹下打开终端 执行cnpm i vue-cli -g...
    Akiko_秋子阅读 3,212评论 1 22
  • ## 框架和库的区别?> 框架(framework):一套完整的软件设计架构和**解决方案**。> > 库(lib...
    Rui_bdad阅读 2,889评论 1 4