码迷,mamicode.com
首页 > 其他好文 > 详细

div实现自适应高度的textarea,实现angular双向绑定

时间:2017-05-05 00:57:03      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:适应   require   聊天   amp   ret   指令   oid   打开方式   pbr   

相信不少同学模拟过腾讯的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双向绑定

标签:适应   require   聊天   amp   ret   指令   oid   打开方式   pbr   

原文地址:http://www.cnblogs.com/zhaohongtian/p/6810329.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!