div实现自适应高度的textarea实现angular双向绑定
- 作者: ZLW55243015
- 来源: 51数据库
- 2021-08-02
相信不少同学模拟过腾讯的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);
}
}
};
});
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
推荐阅读
热点文章
Angular中响应式表单的三种更新值方法详析
7
Angularjs实现下拉框联动的示例代码
7
详解AngularJS跨页面传值(ui-router)
2
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
3
angular2路由切换改变页面title的示例代码
4
Angular2 组件间通过@Input @Output通讯示例
5
Angularjs中ng-repeat的简单实例
3
AngularJS 中ui-view传参的实例详解
4
浅谈Angular路由守卫
4
详解基于Angular4+ server render(服务端渲染)开发教程
4
