点击按钮,在textarea光标位置插入值
应用场景是一个邮件模板配置的功能,需要点击按钮后在textarea光标位置插入占位符(如下图)
解决代码如下
插入动态元素:
<MdButton class="checkBtn" @click="insert('{message}')">{message}</MdButton>
<MdInput type="textarea" id="mailTemplate" v-model="detailForm.mailTemplate" :rows="4" :autosize="{minRows: 10, maxRows: 10}"/>
js:
insert (content) {
let textInput = document.getElementById('mailTemplate');
let area = textInput.getElementsByClassName('ivu-input')[0];
// 获取光标初始索引
let insert = area.selectionStart;
// 拼接字符串的形式来得到需要的内容
area.value = area.value.substr(0, insert) + content + area.value.substr(insert);
//computed不会计算得重新赋值
this.detailForm.mailTemplate = area.value;
},
注:<MdInput>
为基于iview二次封装的input组件,主要是获取到<textarea>
的selectionStart即为光标位置进行字符串拼接,本来想用ref的方式获取结果不行不知道为啥就还得再看看。
关键是!(敲黑板!)改变<textarea>
的value不会改变双向绑定的值,得手动赋值一下
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律