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


Posted in Javascript onJanuary 08, 2017

相信不少同学模拟过腾讯的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 相关文章推荐
js实现的点击数量加一可操作数据库
May 09 Javascript
Jquery 效果使用详解
Nov 23 Javascript
JavaScript实现数据类型的相互转换
Mar 06 Javascript
js中获取jsp表单中radio类型的值简单实例
Aug 15 Javascript
Restify中接入Socket.io报Error:Can’t set headers的错误解决
Mar 28 Javascript
原生javascript实现文件异步上传的实例讲解
Oct 26 Javascript
JavaScript生成指定范围的时间列表
Mar 19 Javascript
详解如何在webpack中做预渲染降低首屏空白时间
Aug 22 Javascript
Layui实现主窗口和Iframe层参数传递
Nov 14 Javascript
js+canvas实现纸牌游戏
Mar 16 Javascript
html+vue.js 实现漂亮分页功能可兼容IE
Nov 07 Javascript
36个正则表达式(开发效率提高80%)
Nov 17 Javascript
JavaScript中日常收集常见的10种错误(推荐)
Jan 08 #Javascript
详解js中==与===的区别
Jan 08 #Javascript
JavaScript 动态三角函数实例详解
Jan 08 #Javascript
你不知道的 javascript【推荐】
Jan 08 #Javascript
js时间控件只显示年月
Jan 08 #Javascript
javascript函数的四种调用模式
Jan 08 #Javascript
jquery与ajax获取特殊字符实例详解
Jan 08 #Javascript
You might like
初学CAKEPHP 基础教程
2009/11/02 PHP
PHP用GD库生成高质量的缩略图片
2011/03/09 PHP
一个PHP二维数组排序的函数分享
2014/01/17 PHP
遍历echsop的region表形成缓存的程序实例代码
2016/11/01 PHP
php基于session锁防止阻塞请求的方法分析
2017/08/07 PHP
关于PHP虚拟主机概念及如何选择稳定的PHP虚拟主机
2018/11/20 PHP
JavaScript 三种不同位置代码的写法
2009/10/25 Javascript
href下载文件根据id取url并下载
2014/05/28 Javascript
15款jQuery分布引导插件分享
2015/02/04 Javascript
vue页面切换过渡transition效果
2018/10/08 Javascript
js自定义input文件上传样式
2018/10/26 Javascript
详解wepy开发小程序踩过的坑(小结)
2019/05/22 Javascript
vue 实现LED数字时钟效果(开箱即用)
2019/12/08 Javascript
使用webpack/gulp构建TypeScript项目的方法示例
2019/12/18 Javascript
教你使用python画一朵花送女朋友
2018/03/29 Python
opencv改变imshow窗口大小,窗口位置的方法
2018/04/02 Python
python实现简单图片物体标注工具
2019/03/18 Python
Tensorflow 1.0之后模型文件、权重数值的读取方式
2020/02/12 Python
python绘制动态曲线教程
2020/02/24 Python
Python判断三段线能否构成三角形的代码
2020/04/12 Python
django中cookiecutter的使用教程
2020/12/03 Python
python实现PolynomialFeatures多项式的方法
2021/01/06 Python
CSS3 渐变(Gradients)之CSS3 径向渐变
2016/07/08 HTML / CSS
巴西最大的家具及装饰用品店:Mobly
2017/10/11 全球购物
泰国演唱会订票网站:StubHub泰国
2018/02/26 全球购物
美国在线乐器和设备商店:Musician’s Friend
2018/07/06 全球购物
泰国的头号网上婴儿用品店:Motherhood.co.th
2019/04/09 全球购物
会计专业毕业生推荐信
2013/11/05 职场文书
内容编辑个人求职信
2013/12/10 职场文书
给导游的表扬信
2014/01/10 职场文书
购房意向书范本
2014/04/01 职场文书
教师求职自荐信
2015/03/26 职场文书
教师聘用意向书
2015/05/11 职场文书
停发工资证明范本
2015/06/12 职场文书
承诺书的签字人,需不需要承担相应的责任?
2019/07/09 职场文书
Dashboard管理Kubernetes集群与API访问配置
2022/04/01 Servers