首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

多行文本控件和富文本控件怎样自动填写

所谓多行文本输入控件,就是网页表单中,因输入内容较多需换行显示的文本输入控件,一般为textarea元素。很多富文本输入框也是对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("木头软件");

复制代码

使用脚本修改多行文本框值

执行以上脚本输入内容后,不会触发控件绑定的事件,如有必要,可以在代码中主动调用相关的事件处理代码。也可以再添加一个填表步骤项目来主动触发事件代码执行。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20221117A048WS00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券