添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

[油猴脚本开发指南]脚本自动化之模拟点击和表单填写

本节主要内容:
首先将介绍模拟点击和表单填写的原理,然后使用脚本实现一个自动化登录论坛的功能

模拟点击

前端开发的同学应该都写过下面类似的代码,主要是监听一个按钮的click事件,用以实现一些功能.

//html
<button id="btn" onclick="click()">按钮</button>
btn.onclick=function(){
alert('按钮被点击了')
$('#btn').click(function(){
alert('按钮被点击了')

我们模拟点击其实就是希望能够执行这个按钮点下后的事件.

方法一:

如果是上面的html的写法,我们可以直接找到点击后的事件,然后直接执行.不过这种方法使用场景有限,不是很推荐.

click();

方法二:

如果是js监听事件的方法,我们可以先用'document.querySelector'找到btn元素,然后执行'btn.click()'.这是比较推荐的方法.当然除了'document.querySelector'外还可以用jQuery,document.getElementByXXX之类的方法,只要能够找到并操作DOM元素就行了.(个人习惯querySelector,后续也使用querySelector来编写)

var btn=document.querySelector('#btn');
btn.click();

表单填写

关于表单填写也就是form,我们需要自动化的实现在input,checkbox,select等元素中填写或者选择我们希望的内容,例如自动选择正确答案和自动填写账号.其实也很简单,我们只需要使用querySelector查到我们想操作的元素就行了.

例如我想操作某个输入框:

var input=document.querySelector('#input');
input.value="油猴中文网";

操作多选框:

var checkbox=document.querySelector('#checkbox');
checkbox.checked=true;


使用自动化登录论坛
接下来使用我们刚刚的内容来实现一个自动化登录论坛的脚本.我们期望的功能是,打开论坛首页时,检测是否登录,如果未登录就自动填写配置好的账号密码进行登录,并且勾上自动登录选项.

第一步,判断是否登录:

在未登录的时候,我们的上方是一个登录框框,而不是用户的信息,那么我们可以查找上方是否有编辑框来判断是否是登录状态.(当然还有其它的很多办法)


按下F12打开开发者工具,选中用户这个框可,可以看见他有一个id和一些其它信息,id一般是这个页面唯一的,那么我们可以直接使用id来查询它,来看看它在不在这个页面上,在就表示没有登录.

代码就像这样:

if(document.querySelector("#ls_username")==null){
//没有找到表示登录了,不再执行后续代码
return;