删除textarea光标所在行之二

本文介绍了一个用于处理文本区域(Textarea)内容的JavaScript脚本,该脚本能将文本内容按行分割并存储为数组,通过聚焦位置确定当前光标所在行,并能删除指定行的内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<textarea id="txt1" style="width:150;height:300">
11111111
22222222
33333333
44444444
55555555
66666666
77777777
88888888
</textarea>
<input type="button" value="DelRow" onclick="DelRow()"><br>
<script>
 
function DelRow()
{
//先把Textarea的数据分开.按/r/n,就是回车符分开.存成数组.
var str = txt1.value;
arrstr = str.split(//r/n/);
for(var i=0;i<arrstr.length;i++)
{
    arrstr[i]=arrstr[i].concat("/r")
}
//alert(arrstr)
/****** Start  取得当标所在的位置pos   Start********/
txt1.focus();
var currentRange=document.selection.createRange();
var workRange=currentRange.duplicate();
txt1.select();
var allRange=document.selection.createRange();
var pos=0;
while(workRange.compareEndPoints("StartToStart",allRange)>0)
{
  workRange.moveStart("character",-1);
  pos++;

currentRange.select();
/******   End  取得当标所在的位置pos   End**********/
//位置和每行的字符长度相减.当小于零时.取得i的值.也就是对应的数组下标.
for(var j=0;j<arrstr.length;j++)
{
    pos-=arrstr[j].length;
 if(pos<0){arrstr.baoremove(j);break;}
}
//合并数组.并显示. 
txt1.value=arrstr.join("") 
}
//删除数组元素.原数组上操作.
Array.prototype.baoremove = function(dx)
{
    if(isNaN(dx)||dx>this.length){return false;}
    this.splice(dx,1);
}
</script>
使用vue3 +step + ts = lang写一个页面,所有代码都在同一个文件;页面有一个叫编辑公式按钮;点击后,弹出一个页面,这个页面分左右两块A、B块;A块在左,B块在右;A块是二级树,带搜索功能;B块分上下三块B1/B2/B3块,B1占B块的60%,B2块占B块的30%,B3块占B块的10%;B1是多功能输入框,输入框支持上下滚动;输入来源分三块,第一块是左侧树,第二块是入由下方多功能按钮区带入,第三块是键盘输入,键盘输入只能数字和英文字符,自动带入的除外;B2是多功能按钮区,分别是+、-、*、/、if、else if、;、return、>、<、=、{、}、(、)等点击按钮,按钮之间间隔5px,点击B2的按钮,自动带入到B1输入框内;其中点击换时,B1输入框自动换,且添加分割线,分割线上下间距1;B1输入框删除时,A块、B2 带入的只能整体删除,不能单个字符删除;B3块有三个按钮靠右排列,分别是公式校验、确认、取消;A块树点击后,自动带入树的值到B1输入框内,展示时显示树的名称,返回的是树的id;B1用户输入只能数字和英文字符,自动带入的除外;B1输入框中的内容起始位正输入框的左上角,距边框5px;B1展示内容样式为随机颜色按钮,点击后,展示左插入、右插入、替换、删除操作,其中删除以右上角角标形式展示;点击B3块确认按钮时,以B1的内容以字符串且保留换符的形式返回,回显时,需要根据所提供的字符串识别分块;
06-22
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值