我来教你制作JS脚本,一键完成学校教务系统的评教!
需求:我们在学校每学期都要完成教师教学评教,但是课程多,评教有点麻烦,我们能不能一键评教所有课程老师的评教呢?
答案肯定是有的。首先登陆你学校的教务系统,我学校的教务系统是正方教务系统。推荐使用Chrome浏览器,登陆到评教页面,再按F12,显示如下图所示的页面。
点中上图的Console 控制台,把下面的代码复制黏贴过去按回车。注意教师评教页面是要等待30秒,才能点击保存的,这是我学校系统为了防止非法的频繁操作。所以要等待完30秒后,再按回车,好了你会发现页面会自动完成选择,并跳转到最后一页,此时你只需要按下提交,就完成了评教!
var iframe = window.top.document.getElementById('iframeautoheight');
var ifdocument = iframe.contentWindow.document;
var subLength = ifdocument.getElementById("pjkc").length - 1;
ifdocument.getElementById("TextBox1").value = - 1; //去掉等待时间
function execution(){
var iframe = window.top.document.getElementById('iframeautoheight');
var ifdocument = iframe.contentWindow.document;
//网站提交后会自动跳转下一课程
var reg = /^DataGrid1__ctl\d+_JS1$/;
var selections = ifdocument.getElementsByTagName("select");
for(var i = 0 ; i< selections.length; i++){
if(reg.test(selections[i].getAttribute("id"))){
selections[i].value = "优秀";
}
}
ifdocument.getElementById("Button1").click();
}
execution();
iframe.onload = function(){
if(subLength -- > 0){
execution();
}
}
那我们来看看具体是怎么实现的。
1.先说下思路:
把学校的教务系统里的 评优select标签的value 改成 “优秀”, 然后再触发下面的保存按钮,因为教务系统点了保存会自动跳转到下一个老师的页面,所以不用我们操心了,我们只需要写好 修改评优select 标签的方法,当 iframe一加载完成就触发这个方法,当评教数到达最后一个的时候停止触发。
2.具体操作细节:
F12大法,查看你学校的评教页面,如图所示:
1)发现评教系统里面的嵌套着一个iframe, 也就是说我们选择的内容都是在 iframe里面的。
所以我们要获取这个 iframe 对象,因为要调用一个 onload 事件。
使用 var iframe = window.top.document.getElementById(‘iframeautoheight’);
获取iframe对象, 其中window.top 就是最顶层的window 对象。
使用 var ifdocument = iframe.contentWindow.document;
获取 iframe的document对象,其中contentWindow就是获取 iframe对象嵌套的 window对象。
使用 var subLength = ifdocument.getElementById(“pjkc”).length – 1;
获取课程的数目,执行到最后一门的时候不再循环下去。
2)有了iframe对象的document对象就很好搞了, 我们写个方法 execution 实现选择每个 下拉框的值,并点击保存。
获取所有select : ifdocument.getElementsByTagName(“select”);
我们来看看下拉框的 ID:
可以看到 select 的 ID 是有规律的。我们可以写个正则匹配:
var reg = /^DataGrid1__ctl\d+_JS1$/;
如果匹配成功,就把 该 select 的 value值修改成你需要的值。最后找到保存按钮的 ID:
调用点击方法就OK了。ifdocument.getElementById(“Button1”).click();
3)但是我发现我学校的系统每个课程评教都设置了30等待时间,然后经我研究,在源码里搜索 Button1关键字 发现如下:
原来它会判断 x 若 x >0就会走定时方法,所以改掉 x 的值就好了,再搜索var x发现:
TextBox1它value 就是30,所以我们修改下它的value。
ifdocument.getElementById(“TextBox1”).value = – 1;
可以看到getvalue()方法 当iframe 一加载完就赋予了 x 的值,所以首次修改了TextBox1 value也不起作用,定时任务已经开始了,所以说要等待30秒后才能在控制台回车执行复制的代码。
4)最后调用一个 iframe对象的onload 事件,当系统自动跳转到下一课程的时候, iframe就会重新加载 加载完后,onload事件就会触发,然后就可以再次调用 execution方法啦。
是不是很简单,如果有条件的话,不妨自己写写看~