div实现自适应高度的textarea实现angular双向绑定
2017-01-08 10:26
866 查看
相信不少同学模拟过腾讯的QQ做一个聊天应用,至少我是其中一个。
过程中我遇到的一个问题就是QQ输入框,自适应高度,最高高度为3row。
如果你也像我一样打算使用textarea,那么很抱歉,你一开始就错了。
textarea不是不可以的,然后我是这样错的。(就是监听scroll 如果出现了,就增加1rows 的高度)然而这样真的很挫
textarea.bind('change','keydown'){ if(scrollTop > 0 ) { textarea.rows += 1 } }
正确的打开方式应该是利用 html5 全局属性,然而在ios 移动端中,仅使用contenteditable,是无法获得焦点的,无法进行输入的,因此需要添加use-select属性
<div contenteditable='true' style='-webkit-use-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-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('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); } } }; });
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!
您可能感兴趣的文章:
相关文章推荐
- javascript TextArea动态显示剩余字符
- jquery的clone方法应用于textarea和select的bug修复
- textarea 在IE和FF下换行无法正常显示的解决方法
- PHP实现将textarea的值根据回车换行拆分至数组
- 关于textarea提交的内容无法换行的解决办法
- 微信小程序 textarea 详解及简单使用方法
- 基于JS实现textarea中获取动态剩余字数的方法
- js实现控制textarea输入字符串的个数,鼠标按下抬起判断输入字符数
- javascript实现textarea中tab键的缩排处理方法
- 一个JavaScript处理textarea中的字符成每一行实例
- js插入字符到textarea的效果代码
- Angular工具方法学习
- jQuery往textarea中光标所在位置插入文本的方法
- Jquery实现textarea根据文本内容自适应高度
- 基于jquery的让textarea自适应高度的插件
- 使用jquery给input和textarea设定ie中的focus
- jQuery实现限制textarea文本框输入字符数量的方法
- textarea 在浏览器中固定大小和禁止拖动的实现方法
- JQuery统计input和textarea文字输入数量(代码分享)
- 用javascript获取textarea中的光标位置