网站首页 > 技术文章 正文
所谓多行文本输入控件,就是网页表单中,因输入内容较多需换行显示的文本输入控件,一般为textarea元素。很多富文本输入框也是对textarea进行包装。
<textarea name="Content" rows="8" style="width: 380px"></textarea>
自动填写多行文本输入控件的五种方法
1、通过修改元素属性填表
textarea元素比较特殊,在html中直接指定value属性值是无效的。修改textarea元素的text属性,可以实现自动填表,但要求textarea元素未被脚本赋值的情况下text才有效。修改text属性不会触发元素绑定的事件,但在木头浏览器填写项目中,可以明确指定填表前和填表后需要触发的事件。
2、由系统向浏览器发送数据
在window系统下,这几乎是一个万能的方法,支持中文输入,获得控件元素后,填写属性设置为KeyboardSend。在自动输入前,浏览器会自我激活为当前活动窗口,同时把输入焦点转移到设定的多行文本控件上。在输入过程中,不能手工干预,不能让控件失去焦点,也不能切换到别的程序窗口。输入远程会触发控件绑定的事件代码。
3、模拟人工键盘操作
获取元素后,把填写属性设置为Keyboard,能达到人工按下实体键盘一样的效果,因此不能输入中文,执行时同样会自动激活浏览器窗体,输入焦点转移到多选文本控件上。输入过程中会触发元素绑定的相关事件。
4、模拟键盘事件
在不按下键盘的情况下,直接产生按键事件作用于当前活动窗口,获取元素后设置填写属性为KeyboardEvent。与模拟人工操作效果一样,自动激活浏览器窗体,定位输入焦点到多行文本控件上才能完成输入,亦不支持中文输入,会触发元素控件绑定的脚本事件。
5、执行脚本代码控制输入
在项目管理窗口中,创建一个脚本代码的步骤,执行JavaScript代码修改textarea的value属性值。注意:textarea虽然在html中没有value属性,但在JavaScript代码中是支持的。不管textarea是否被赋初值,都不影响脚本执行填表效果。
document.getElementsByTagName("textarea")[0].value="木头软件";
也可以使用JQuery代码,只要勾选【引入JQuery】,浏览器自动引用JQuery库
$("textarea").eq(0).val("木头软件");
执行以上脚本输入内容后,不会触发控件绑定的事件,如有必要,可以在代码中主动调用相关的事件处理代码。也可以再添加一个填表步骤项目来主动触发事件代码执行。
猜你喜欢
- 2024-09-14 前端HTML篇--04HTML文本标签(html中的文本标签)
- 2024-09-14 HTML超文本标记语言怎么学?(html超文本标记语言代码)
- 2024-09-14 HTML介绍——入门级(html基础入门)
- 2024-09-14 HTML技巧篇:如何让单行文本以及多行文本溢出显示省略号(……)
- 2024-09-14 HTML基础2019-1-21(html基础选择器)
- 2024-09-14 Python小案例71- HTML基础及语法(python3 html)
- 2024-09-14 4.HTML文本元素(html文档的常用元素)
- 2024-09-14 html基础必备,前端小白一看就会(html前端怎么学)
- 2024-09-14 HTML的一些常用的语法写法(html语法基本结构)
- 2024-09-14 初识Html(初识的唯美短句)
- 1512℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 553℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 503℃MySQL service启动脚本浅析(r12笔记第59天)
- 481℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 479℃启用MySQL查询缓存(mysql8.0查询缓存)
- 459℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 439℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 436℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)