1. 程式人生 > >div實現自適應高度的textarea,實現angular雙向綁定

div實現自適應高度的textarea,實現angular雙向綁定

amp 屬性 top 方式 androi android 可編輯 str ==

相信不少同學模擬過騰訊的QQ做一個聊天應用,至少我是其中一個。

過程中我遇到的一個問題就是QQ輸入框,自適應高度,最高高度為3row。

如果你也像我一樣打算使用textarea,那麽很抱歉,你一開始就錯了。

textarea不是不可以的,然後我是這樣錯的。(就是監聽scroll 如果出現了,就增加1rows 的高度)然而這樣真的很挫

 textarea.bind(‘change‘,‘keydown‘){
    if(scrollTop > 0 ) {
        textarea.rows += 1
    }
}

正確的打開方式應該是利用 html5 全局屬性,然而在ios 移動端中,僅使用contenteditable,是無法獲得焦點的,無法進行輸入的,因此需要添加user-select屬性

<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);
      }
    }
  };
});
技術分享

  

div實現自適應高度的textarea,實現angular雙向綁定