相信很多同窗模擬過騰訊的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); } } }; });