div实现自适应高度的textarea,实现angular双向绑定
来源:互联网 发布:中国工信部济南软件 编辑:程序博客网 时间:2024/04/28 12:07
相信不少同学模拟过腾讯的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); } } };});
0 0
- div实现自适应高度的textarea,实现angular双向绑定
- div模拟实现textarea(高度自适应)
- div模拟textarea文本域轻松实现高度自适应
- div模拟textarea以实现高度自适应实例页面
- div模拟textarea以实现高度自适应实例页面
- div模拟textarea文本域轻松实现高度自适应
- div模拟textarea文本域轻松实现高度自适应
- div模拟textarea文本域轻松实现高度自适应
- div模拟textarea文本域轻松实现高度自适应
- div模拟textarea文本域轻松实现高度自适应
- textarea如何实现高度自适应?
- jquery实现textarea高度自适应
- textarea如何实现高度自适应?
- textarea如何实现高度自适应
- textarea如何实现高度自适应
- jquery实现textarea 高度自适应
- textarea如何实现高度自适应?
- textarea如何实现高度自适应?
- Mysql基础——where 过滤数据
- List remove()方法介绍
- 在 XSLT 中用递归实现循环
- Eclipse中的jsp文件运行时出现中文乱码
- cc2541- I/O 简介
- div实现自适应高度的textarea,实现angular双向绑定
- React-Native 在android不支持gif图 -- 解决方案!(转)
- spark厦大---特征抽取:CountVectorizer -- spark.ml
- 1.HTML
- Java OOP之封装性和this关键字的使用
- 二四、vue实现todolist
- windows程序设计(一)
- Vertica DBD 分析优化设计
- stm32中定时器中断的套路