div实现自适应高度的textarea实现angular双向绑定
相信不少同学模拟过腾讯的QQ做一个聊天应用,至少我是其中一个。
过程中我遇到的一个问题就是QQ输入框,自适应高度,最高高度为3row。
如果你也像我一样打算使用textarea,那么很抱歉,你一开始就错了。
textarea不是不可以的,然后我是这样错的。(就是监听scroll如果出现了,就增加1rows的高度)然而这样真的很挫
textarea.bind('change','keydown'){ if(scrollTop>0){ textarea.rows+=1 } }
正确的打开方式应该是利用html5全局属性,然而在ios移动端中,仅使用contenteditable,是无法获得焦点的,无法进行输入的,因此需要添加use-select属性
<divcontenteditable='true'style='-webkit-use-select:text'></div> //不同浏览器,支持度,和实现方式也有点不一样,android和ios默认webkit内核,所以使用这个够了
在angular中使用可编辑的div:——》angular的ng-model指令只用于select,input,textarea,不适用于div,所以要进一步封装
/* *可编辑的div *应用于发表评论中有表情的时候,div中添加img(表情) *<divcontenteditablestrp-br='true'style='-webkit-use-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('blurkeyupchange',function(){ scope.$evalAsync(read); }); read();//initialize functionread(){ varhtml=element.html(); if(attrs.stripBr&&html=='<br>'){//清除<br> html=''; } ngModel.$setViewValue(html); } } }; });
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!