div实现自适应高度的textarea实现angular双向绑定
程序员文章站
2023-02-25 17:29:14
相信不少同学模拟过腾讯的qq做一个聊天应用,至少我是其中一个。
过程中我遇到的一个问题就是qq输入框,自适应高度,最高高度为3row。
如果你也像我一样打算使用text...
相信不少同学模拟过腾讯的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和Vue双向数据绑定的实现原理(重点是vue的双向绑定)
-
angular4自定义组件非input元素实现ngModel双向数据绑定的方法
-
div实现自适应高度的textarea实现angular双向绑定
-
自定义Angular指令与jQuery实现的Bootstrap风格数据双向绑定的单选与多选下拉框
-
详解Angular中实现自定义组件的双向绑定的两种方法
-
基于jQuery实现左右div自适应高度完全相同的代码
-
Vue、angular等框架实现双向绑定的原理,核心机制是使用了Object.defineProperty
-
浅谈angular.js中实现双向绑定的方法$watch $digest $apply
-
Angular和Vue双向数据绑定的实现原理(重点是vue的双向绑定)
-
Vue中textarea自适应高度方案的实现