欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue实现textarea固定输入行数与添加下划线样式的思路详解

程序员文章站 2022-06-30 09:01:31
先上效果图###   textarea下划线 设置一张1*35 //行高 的图片 , 设置背景图即可. background: url('./im...

先上效果图###

Vue实现textarea固定输入行数与添加下划线样式的思路详解 

textarea下划线

设置一张1*35 //行高 的图片 , 设置背景图即可.

background: url('./img/linebg.png') repeat;
border: none;outline: none;overflow: hidden;
line-height: 35px;//注意行高要和背景图高度一致resize: none;

固定输入行数

需求:用户固定不论多少字节,只能输入2行.

因为是限制行数,所以不能用maxlength设置.

实现思路

首先想到计算出用户输入了几行,然后超出部分字符删除掉就ok.

<textarea class='textarea' @scroll='textsrc' v-model='text.headquarters' ref='headquarters' rows="2"></textarea>

首先取出

textarea元素的整体高度,然后除一下行高很轻松的到目前输入到几行.

因为如果用户一次复制一大段文字 ,  粘贴到textarea里则会直接出现多行 , 删除字符串超出部分换行还会触发scroll事件, 所以用if语句判断一下是否满足了限制.

发现多行代码排版错误,贴张图吧.

Vue实现textarea固定输入行数与添加下划线样式的思路详解 

textsrc() {  
this.$refs.headquarters.scrollto(0, 0)  
let linenumber = this.$refs.headquarters.scrollheight / 35;  
if (linenumber => 2) {   
this.state = false;  
} else {   
this.state = true;  
};  
!this.tiemr && !this.state && this.tiemer();  
this.tiemr && this.state && clearinterval(this.tiemr);  
if (this.state) {   
this.tiemr = null;  
}  
},

写一个删除多余字符函数

Vue实现textarea固定输入行数与添加下划线样式的思路详解 

tiemer() 
{  
this.tiemr = setinterval(() => 
{   
this.text.headquarters = this.text.headquarters.slice(   
0,   
this.text.headquarters.length - 1   
);   
if (this.$refs.headquarters.scrollheight / 35 == 2)
{   
clearinterval(this.tiemr)   
this.tiemr = null   
this.state = true   
}
  },
 10);  
 },

最后贴一下 ,欢迎有更好方法的大神赐教.

总结

以上所述是小编给大家介绍的使用vue实现textarea固定输入行数与添加下划线样式,希望对大家有所帮助