键盘出现时,离子内容不会调整大小

时间:2016-01-14 09:40:04

标签: angularjs keyboard ionic-framework ionic

我的应用程序具有聊天功能,效果很好,除了一部分,当键盘出现时,离子内容不会调整到适当的高度,所以当我想滚动到顶部时我卡住了并且标题完全消失。视图有一个标题,内容和页脚,我想要的是在键盘上方显示的页脚和要调整大小的内容,使其适合页眉和页脚栏。我创建的视图如下:

<ion-view id="userMessagesView" cache-view="true" flow-init flow-name="imageTemp.imageTemp" ng-if="!inChatSettings">
  <div class="loader-center" ng-if="!doneLoading">
    <div class="loader">
      <i class="icon ion-loading-c"></i>
    </div>
  </div>
  <div class="loader-center" ng-if="errorLoading">
    <div class="loader">{{'error_loading_messages'|translate}}</div>
  </div>
  <ion-content class="has-header has-footer" has-bouncing="true" delegate-handle="userMessageScroll" style="background:red;">
    <ion-refresher pulling-text="{{'pull_load_earlier'|translate}}" on-refresh="loadMore()"></ion-refresher>
    <div ng-repeat="message in messageThread.messages | orderBy : 'postDate'" class="message-wrapper">
      <div class="chat-bubble" ng-class="{ false: 'left', true:'right'}[{{message.postedBy|isCurrentUser}}]">
        <div class="message-detail">
          <span class="bold">{{message.postedBy.name}}</span>
        </div>
        <div class="message" ng-bind-html="message.message | nl2br" autolinker></div>
        <img ng-src="{{message.imageUrl}}" ng-if="message.imageUrl"/>
        <small am-time-ago="message.postDate">{{message.postDate|timeago}}</small>
      </div>
      <div class="cf"></div>
    </div>
  </ion-content>
  <ion-footer-bar class="bar-light message-footer">
    <button class="button button-icon icon icon-upload" flow-btn flow-file-added="imageUploaded($file)" flow-name="imageTemp.imageUrlTemp"></button>
    <label class="item-input-wrapper" for="newmessage">
      <textarea focus-me="input.focusInput" id="newmessage" ng-model="input.message" value="" required minlength="1" maxlength="1500" msd-elastic></textarea>
    </label>
    <button class="button button-clear" type="submit" ng-disabled="!input.message || input.message === ''" ng-click="sendMessage()" translate="send"></button>
  </ion-footer-bar>
</ion-view>

我尝试将键盘附加属性添加到离子页脚栏,但是当我添加它时,页脚只会变大。此外,页脚已经停留在键盘顶部,因此看起来不需要。我有以下情况,看来当我输入内容时,视图会上升一点。

这是键盘显示的时间: When the keyboard is shown

这是键盘隐藏的时候: When the keyboard is hidden

当键盘出现时,你们是否知道如何将离子含量调整到正常高度?

1 个答案:

答案 0 :(得分:0)

我尝试了一些事情,问题似乎消失了,但我不认为解决方案是正确的,或者这实际上是解决问题的方法。所以,如果有人有更好的解决方案,请分享。我要做的第一件事就是包括Ionic键盘插件,以便根据键盘获取事件。

在CSS中,我添加了:

$scope.$on('taResize', function (e, ta) {
    if(!ta || !footerBar) return;

    var taHeight = ta[0].offsetHeight + 10;
    var newHeight = (taHeight < 44) ? 44 : taHeight;

    scroller.style.bottom = newHeight + 'px';
    footerBar.style.height = newHeight + 'px';
});

在我的控制器中,我添加了以下代码:

{{1}}