码迷,mamicode.com
首页 > 微信 > 详细

微信公众号系列 --- ionic在IOS的键盘弹出问题

时间:2016-06-23 20:45:50      阅读:587      评论:0      收藏:0      [点我收藏+]

标签:

  在使用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的键盘弹出问题

标签:

原文地址:http://www.cnblogs.com/HeJason/p/5611989.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!