zoukankan      html  css  js  c++  java
  • div实现自适应高度的textarea,实现angular双向绑定

    相信不少同学模拟过腾讯的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);
          }
        }
      };
    });
    复制代码

      

  • 相关阅读:
    hdu 2680 最短路径(dijkstra算法+多源最短路径单源化求最小值)
    kmp算法
    STP根交换机,指定端口,根端口,阻塞端口
    python,django安装
    交换机access与trunk口
    树状数组
    hdoj 2191(多重背包)
    hdoj 2601(判断N=i*j+i+j)
    二维背包经典问题
    hdoj 2602(背包)
  • 原文地址:https://www.cnblogs.com/zhaohongtian/p/6810329.html
Copyright © 2011-2022 走看看