微信公众号系列 --- ionic在IOS的键盘弹出问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微信公众号系列 --- ionic在IOS的键盘弹出问题相关的知识,希望对你有一定的参考价值。
在使用ionic开发ios系统微信的时候会有一个苦恼的问题,填写表单的时候键盘会挡住输入框,其实并不算什么大问题,只要用户输入一个字就可以立刻看见输入框了。
可惜的是,有些客户是不讲理的,他才不管这个问题,反正就是不行,所以在一天睡觉的时候突然惊醒,想出来这个方案。
我就不仔细讲代码了,直接上图
angular.module(‘MyApp‘)
.directive(‘focusInput‘, [‘$ionicScrollDelegate‘, ‘$window‘, ‘$timeout‘, ‘$ionicPosition‘, function ($ionicScrollDelegate, $window, $timeout, $ionicPosition) {
return {
restrict: ‘A‘,
scope: false,
link: function ($scope, iElm, iAttrs, controller) {
if (ionic.Platform.isIOS()) {
iElm.on(‘focus‘, function () {
var top = $ionicScrollDelegate.getScrollPosition().top;
var eleTop = ($ionicPosition.offset(iElm).top) / 2
var realTop = eleTop + top;
$timeout(function () {
if (!$scope.$last) {
$ionicScrollDelegate.scrollTo(0,realTop);
} else {
try {
var aim = angular.element(document).find(‘.scroll‘)
aim.css(‘transform‘, ‘translate3d(0px,‘ + ‘-‘ + realTop + ‘px, 0px) scale(1)‘);
$timeout(function () {
iElm[0].focus();
console.log(2);
}, 100)
} catch (e) {
}
}
}, 500)
})
}
}
}
}])
以上是关于微信公众号系列 --- ionic在IOS的键盘弹出问题的主要内容,如果未能解决你的问题,请参考以下文章
ios 最新系统bug与解决——微信公众号中弹出键盘再收起时,原虚拟键盘位点击事件无效
Ionic+AngularJS 开发的页面在微信公众号下显示不出来原因查究