相信很多同窗模拟过腾讯的QQ作一个聊天应用,至少我是其中一个。html
过程当中我遇到的一个问题就是QQ输入框,自适应高度,最高高度为3row。html5
若是你也像我同样打算使用textarea,那么很抱歉,你一开始就错了。android
textarea不是不能够的,而后我是这样错的。(就是监听scroll 若是出现了,就增长1rows 的高度)然而这样真的很挫ios
textarea.bind('change','keydown'){ if(scrollTop > 0 ) { textarea.rows += 1 } }
正确的打开方式应该是利用 html5 全局属性,然而在ios 移动端中,仅使用contenteditable,是没法得到焦点的,没法进行输入的,所以须要添加user-select属性web
<div contenteditable='true' style='-webkit-user-select:text'></div>
//不一样浏览器,支持度,和实现方式也有点不同,android和ios默认webkit内核,因此使用这个够了
在angular中使用可编辑的div:——》 angular的ng-model指令只用于select,input,textarea,不适用于div,因此要进一步封装浏览器
/* * 可编辑的div * 应用于发表评论中有表情的时候,div中添加img(表情) * <div contenteditable strp-br='true' style='-webkit-user-select:text'></div> */ app.directive('contenteditable', function() { return { restrict: 'A', require: '?ngModel', link: function(scope, element, attrs, ngModel) { if (!ngModel) return; ngModel.$render = function() { element.html(ngModel.$viewValue || ''); }; element.on('blur keyup change', function() { scope.$evalAsync(read); }); read(); // initialize function read() { var html = element.html(); if ( attrs.stripBr && html == '<br>' ) { //清除 <br> html = ''; } ngModel.$setViewValue(html); } } }; });