我的应用程序具有聊天功能,效果很好,除了一部分,当键盘出现时,离子内容不会调整到适当的高度,所以当我想滚动到顶部时我卡住了并且标题完全消失。视图有一个标题,内容和页脚,我想要的是在键盘上方显示的页脚和要调整大小的内容,使其适合页眉和页脚栏。我创建的视图如下:
<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>
我尝试将键盘附加属性添加到离子页脚栏,但是当我添加它时,页脚只会变大。此外,页脚已经停留在键盘顶部,因此看起来不需要。我有以下情况,看来当我输入内容时,视图会上升一点。
当键盘出现时,你们是否知道如何将离子含量调整到正常高度?
答案 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}}