鄙人来本公司前未用过ionic框架,但由于ionic是基于angularjs封装的,正好我用过angularjs,很荣幸的面试就过了,然后通过该网站http://www.ionic.wang(后面简称网站i)边学ionic边做项目。

  ionic刚踩过的坑--$ionicGesture!现总结下$ionicGesture,希望对用到该框架的童鞋有所帮助!

  网站i对$ionicGesture的介绍如下:

  在一个元素上添加一个事件监听器。

$ionicGesture.on(eventType, callback, $element)

  在一个元素上移除一个手势事件监听器。

$ionicGesture.off(eventType, callback, $element)

  参数介绍:

    参数              类型                详情
eventType string 监听的手势事件。
callback function(e) 当手势事件发生时触发的事件。
$element element angular元素监听的事件

  网站i这对$ionicGesture的介绍把我坑的不要不要的,.on()方法没错,.off()参数不对啊!

  这里的off()方法我按网站i的介绍做完,弄了好久都不行,后来按住alt点击$ionicGesture.off进去看源码是这样的才知道网站i介绍该方法错了。

  现整理汇总如下:

$ionicGesture服务--注册/解除手势事件监听

  注册手势事件监听函数

$ionicGesture.on(eventType, callback, $element)
on()方法返回的是一个ionic.gesture对象,可供解除监听用。

参数介绍:

  • 参数eventType是支持的事件类型;
  • 参数callback指定监听函数;
  • 参数$element是要绑定事件的jqLite元素;
  • 参数options是on方法返回对象的一个子对象options。

  解除手势事件监听函数

$ionicGesture.off(gesture,eventType,callback)

  参数介绍:

  • 参数gesture是on()方法返回的结果对象;
  • 参数eventType是支持的事件类型;
  • 参数callback是要移除的监听函数。

注意:canllback默认参数event,后面代码有提到。

  $ionicGesture服务支持的事件类型有:

hold, tap, doubletap, drag, dragstart, dragend, dragup, dragdown, dragleft, dragright, swipe, swipeup, swipedown, swipeleft, swiperight, transform, transformstart, transformend, rotate, pinch, pinchin, pinchout, touch, release

举个例子:

结构层:

<div>
<p>注册、解除手势事件都是按顺序,先button1在button2</p>
<p>点击bind一次button注册一次事件</p>
<button ng-click="add()">bind</button>
<p>点击unbind一次button解除一次事件</p>
<button ng-click="delete()">unbind</button><br><br>
<button id="idCardNick">idCardNick button1</button><br><br>
<button id="licenseNick">licenseNick button2</button>
</div>

  只为实现简单的效果,样式比较呵呵!

  效果:bind、unbind按钮注册、解除手势事件,都是按顺序,先button1在button2。

行为层:

  写在末尾的公用方法

        $scope.add=function(){
if($scope.data.length<2){$scope.data.push('nick');}
};
$scope.delete=function(){
$scope.data.pop();
};

  .on()和.off()的监听函数

    function clickFn(ev,idx){
//这里默认的arguments是event 自定义的参数idx无法获取??
console.log(arguments);
console.log(idx);//undefined
console.log($scope.idx);//这样可以获取idx对象
};
这里要注意的就是监听函数的默认参数event,我开始天真的写成下面这样
function clickFn(idx){
  ……
}

这样写坑死我啦,后来打桩console.log(idx);结果打印出来是event,我勒个去!

监听data.length动态添加删除click事件
  $scope.data=[];
  var clickGesture0,clickGesture1,unbindWatch;
  unbindWatch=$scope.$watch('data.length',function(newval,oldval){
if(newval==0){
if(clickGesture0){OffclickFn(clickGesture0);}
if(clickGesture1){OffclickFn(clickGesture1);}
}else if(newval==1){
clickGesture0=AddclickFn('#idCardNick',0);
if(clickGesture1){OffclickFn(clickGesture1);}
}else if(newval==2){
clickGesture1=AddclickFn('#licenseNick',1);
}else{//不用时为了性能销毁watch
unbindWatch();
}
console.log(clickGesture0);
});

添加监听手势函数AddclickFn这里有2中写法  

  写法一:

    function AddclickFn(selector,idx){
return $ionicGesture.on('click',function(){
console.log(arguments);
console.log(idx);//这样可以获取idx
},angular.element(document.querySelector(selector)));
};

这样写$ionicGesture.on()的监听函数callback就可以获取参数idx,但是这样写$ionicGesture.off()就不能解除callback监听函数了,所以我写成了第二种写法。

  写法二:

function AddclickFn(selector,idx){
return $ionicGesture.on('click',clickFn,angular.element(document.querySelector(selector)),$scope.idx={idx:idx});
};

  将idx存入options.idx在作为对象存入$scope.idx,这样clickFn就可以使用$scope.idx.idx,即参数idx的值。

  这里虽然写法二能实现效果,但我总感觉这样写不好,希望有大牛能给点建议,给我留言或者qq联系,多谢!

  移除手势监听函数:

 function OffclickFn(clickGesture){
$ionicGesture.off(clickGesture,'click',clickFn);
};

我把需要注意的地方都加注释了,上完整代码:

<!DOCTYPE html>
<html ng-app="nickApp">
<head>
<meta charset="utf-8" name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no,width=device-width,height=device-height">
<script src="lib/ionic/js/ionic.bundle.min.js"></script>
<link rel="stylesheet" type="text/css" href="lib/ionic/css/ionic.min.css">
</head>
<body ng-controller="nickCtrl">
<div>
<p>注册、解除手势事件都是按顺序,先button1在button2</p>
<p>点击bind一次button注册一次事件</p>
<button ng-click="add()">bind</button>
<p>点击unbind一次button解除一次事件</p>
<button ng-click="delete()">unbind</button><br><br>
<button id="idCardNick">idCardNick button1</button><br><br>
<button id="licenseNick">licenseNick button2</button>
</div>
<script>
/* http://www.ionic.wang/js_doc-index-id-58.html
on(eventType, callback, $element)
off(eventType, callback, $element)
参数 类型 详情
eventType string 监听的手势事件。
callback function(e) 当手势事件发生时触发的事件。
$element element angular元素监听的事件。*/ /*
//完整汇总:
$ionicGesture服务--注册/解除手势事件监听:
on(eventType,callback,$element,options) - 注册手势事件监听函数
参数eventType是支持的事件类型;
参数callback指定监听函数;
参数$element是要绑定事件的jqLite元素。
参数options是on方法返回对象的一个子对象options
on()方法返回的是一个ionic.gesture对象,可供解除监听用。
off(gesture,eventType,callback) - 解除手势事件监听函数
参数gesture是on()方法返回的结果对象,
参数eventType是支持的事件类型
参数callback是要移除的监听函数。
$ionicGesture服务支持的事件类型有:
hold, tap, doubletap, drag, dragstart, dragend, dragup, dragdown, dragleft, dragright, swipe, swipeup, swipedown, swipeleft, swiperight, transform, transformstart, transformend, rotate, pinch, pinchin, pinchout, touch, release*/
angular.module('nickApp',['ionic'])
.controller('nickCtrl', ['$scope','$ionicGesture',
function ($scope,$ionicGesture){
$scope.data=[];
var clickGesture0,clickGesture1,unbindWatch; //监听data.length动态添加删除click事件
unbindWatch=$scope.$watch('data.length',function(newval,oldval){
if(newval==0){
if(clickGesture0){OffclickFn(clickGesture0);}
if(clickGesture1){OffclickFn(clickGesture1);}
}else if(newval==1){
clickGesture0=AddclickFn('#idCardNick',0);
if(clickGesture1){OffclickFn(clickGesture1);}
}else if(newval==2){
clickGesture1=AddclickFn('#licenseNick',1);
}else{//不用时为了性能销毁watch
unbindWatch();
}
console.log(clickGesture0);
}); /*function AddclickFn(selector,idx){
return $ionicGesture.on('click',function(){
console.log(arguments);
console.log(idx);//这样可以获取idx
},angular.element(document.querySelector(selector)));
};*/
function AddclickFn(selector,idx){//将idx存入options.idx在作为对象存入$scope.idx
return $ionicGesture.on('click',clickFn,angular.element(document.querySelector(selector)),$scope.idx={idx:idx});
}; /*
按住alt点击$ionicGesture.off进去看源码是这样的
才知道ionic.wang这网站介绍gusture方法错了
off: function(gesture, eventType, cb) {
return window.ionic.offGesture(gesture, eventType, cb);
}*/ $scope.add=function(){
if($scope.data.length<2){$scope.data.push('nick');}
};
$scope.delete=function(){
$scope.data.pop();
}; function clickFn(ev,idx){
//这里默认的arguments是event 自定义的参数idx无法获取??
console.log(arguments);
console.log(idx);//undefined
console.log($scope.idx);//这样可以获取idx对象
};
function OffclickFn(clickGesture){
$ionicGesture.off(clickGesture,'click',clickFn);
}; }]); </script>
</body>
</html>

再唠叨下:上面写法二我总感觉不好,希望有大牛能给点建议,给我留言或者qq联系,多谢!

ionic之$ionicGesture手势(大坑)的更多相关文章

  1. ionic之AngularJS——手势事件

    长按 : on-hold 在屏幕同一位置按住超过500ms,将触发on-hold事件: 你可以在任何元素上使用这个指令挂接监听函数: <any on-hold=“…”>…</any& ...

  2. angularjs+ionic的app端分页和条件

    做app项目积分商城的商品列表需要分页显示 实现: ionic滚动条:ion-scroll 用于创建一个可滚动的容器. 附:菜鸟教程:http://www.runoob.com/ionic/ionic ...

  3. 总结angular+ionic项目中的问题

    1:tab的路由导向问题 运用ion-tabs时,第一个ion-tabs标签下的href功能会覆盖掉路由中定义的默认路由(进入应用后直接加载href指向的组件). 解决方法:多写一个ion-tabs标 ...

  4. Ionic Js七:手势事件

    1.on-hold 长按的时间是500毫秒. HTML 代码 <button on-hold="onHold()" class="button">长 ...

  5. Ionic4.x Javascript 扩展 ActionSheet Alert Toast Loading 以及 ionic 手势相 关事件

    1.ActionSheet 官方文档:https://ionicframework.com/docs/api/action-sheet <ion-header> <ion-toolb ...

  6. ionic 禁用 手势 滑动返回

    $ionicConfigProvider.views.swipeBackEnabled(false); 在 应用的 config里面 配置下 上面的那句话 就OK了.

  7. 160914、ionic指令简单布局

    1) 添加引用类库(ionic样式和ionic js文件) 2) 标题栏,页脚栏,内容区 3) Js引入ionic类库,添加页面操作方法和对象 4) 数据初始化 5) Html页面绑定方法和对象 &l ...

  8. ionic基础知识

    ion-header-bar(头部 页眉) 在内容顶部添加一个固定header栏. 用法 <ion-header-bar align-title="left" class=& ...

  9. Ionic学习笔记3_ionic指令简单布局

    1)   添加引用类库(ionic样式和ionic js文件) 2)   标题栏,页脚栏,内容区 3)   Js引入ionic类库,添加页面操作方法和对象 4)   数据初始化 5)   Html页面 ...

随机推荐

  1. Chrome出了个小bug:论如何在Chrome下劫持原生只读对象

    Chrome出了个小bug:论如何在Chrome下劫持原生只读对象 概述 众所周知,虽然JavaScript是个很灵活的语言,浏览器里很多原生的方法都可以随意覆盖或者重写,比如alert.但是为了保证 ...

  2. 【大型网站技术实践】初级篇:借助Nginx搭建反向代理服务器

    一.反向代理:Web服务器的“经纪人” 1.1 反向代理初印象 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从 ...

  3. CodeSimth - .Net Framework Data Provider 可能没有安装。解决方法

    今天想使用CodeSimth生成一个sqlite数据库的模板.当添加添加数据库的时候发现: .Net Framework Data Provider 可能没有安装. 下面找到官方的文档说明: SQLi ...

  4. 初探Vue

    Vue.js(读音/vju:/,类似于view),是近来比较火的前端框架,但一直没有怎么具体了解.实现过,就知道个啥的MVVM啦,数据驱动啦,等这些关于Vue的虚概念. 由于最近,小生在公司中,负责开 ...

  5. Spring Enable annotation – writing a custom Enable annotation

    原文地址:https://www.javacodegeeks.com/2015/04/spring-enable-annotation-writing-a-custom-enable-annotati ...

  6. slf4j中的MDC

    slf4j中MDC是什么鬼 slf4j除了trace.debug.info.warn.error这几个日志接口外,还可以配合MDC将数据写入日志.换句话说MDC也是用来记录日志的,但它的使用方式与使用 ...

  7. intellij idea 13&14 插件推荐及快速上手建议

    IntelliJIDEA插件安装 首页 > blog Tags : intellij IDEA插件安装 更新日期: 2015-04-29 IntelliJ IDEA插件下载地址: http:// ...

  8. 周末聊聊IT人员的人脉观:关于帮妹子找兼职有感

    背景: 前几天,有个认识了好几年的网友,现在是大学生,在厦门读大一,说和她同学要一起到广州找兼职,看我有没有介绍. 像我这么积极热心善良的人,就说帮她找找看,结果问了几次,没消息,只好诚实的回复人家, ...

  9. php杂记(二)

    1.获取客户端真实IP if (!empty($_SERVER['HTTP_CLIENT_IP'])) { $onlineip = $_SERVER['HTTP_CLIENT_IP']; } else ...

  10. TDD原则

    TDD 介绍 测试驱动开发,或者叫 TDD,是一个敏捷方法,通过确保在代码是先前手动编写测试用 例,用测试来驱动开发,从而翻转开发生命周期(它不只是作为一种校验工具). TDD 的原则很简单的: 只有 ...