JS實(shí)現(xiàn)問卷星自動(dòng)填問卷腳本并在兩秒自動(dòng)提交功能
腳本只使用問卷星,多選題目前為選中任意選項(xiàng)數(shù)量?。。。。。?!
最近看到很多群里都在發(fā)問卷連接,各種求幫忙,正好這兩天沒任務(wù),嘗試寫了自動(dòng)填問卷的腳本,類似的腳本網(wǎng)上已經(jīng)有了,但是后來問卷星加了驗(yàn)證,并且多選題已經(jīng)不能適用
腳本使用方式(以Firefox為例):
一:鼠標(biāo)移動(dòng)到瀏覽器地址欄下空白處,右鍵,新建書簽
二:填寫名稱(任意),代碼復(fù)制到地址欄中
三:打開問卷星連接,然后點(diǎn)擊剛剛添加的書簽,即可。
代碼:
javascript: void ( (function () { var hash = {}; var a = document.evaluate('//input[(@type="radio") and not(@value="0")]//@name', document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null); if (a.snapshotLength){ for (var i = 0; i < a.snapshotLength; i++) { if (!(a.snapshotItem(i).value in hash)) hash[a.snapshotItem(i).value] = 0; hash[a.snapshotItem(i).value]++; } for (i in hash) { document.evaluate('//input[(@type="radio") and not(@value="0") and @name="' + i + '"]', document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null).snapshotItem(Math.floor(Math.random() * hash[i])).click(); } } var array = new Array(); var as = document.getElementsByTagName("a"); var preName = ""; var change = false; for(var i=0; i < as.length; i++){ if(as[i].getAttribute("rel") != null && as[i].nextSibling.getAttribute("type") == "checkbox"){ var name = as[i].nextSibling.getAttribute("name"); var check = as[i].nextSibling.getAttribute("checked"); if(check == "checked"){ as[i].click(); } if(preName == "" || preName == name){ if(Math.random() * 10 > 5){ as[i].click(); change = true; } } var next = as[i + 1]; if(next.getAttribute("rel") != null && next.nextSibling.getAttribute("type") == "checked" && next.getAttribute("name") != name){ if(!change){ as[i].click(); } change = false; } if(i == as.length - 1 && !change){ as[i].click(); } preName = name; } } var objs = document.getElementsByTagName("textarea"); for (var i = 0; i < objs.length; i++){ objs[i].focus(); objs[i].value = "最好的意見就是沒有意見,哈哈哈哈哈哈哈"; objs[i].blur(); } var choose = document.getElementsByTagName("select"); for (var i = 0; i < choose.length; i++) { choose[i].focus(); choose[i].value = "1"; choose[i].blur(); } })()); function validate(){return true;} var btn = document.getElementById("submit_button"); window.setTimeout(btn.click(),2000);
之前問卷星的前端加入了一個(gè)隱藏的選擇題,如果直接遍歷頁(yè)面上的input標(biāo)簽,會(huì)把這道題一起做了,然后validate函數(shù)執(zhí)行的時(shí)候會(huì)報(bào)錯(cuò),提示非法填問卷?。。?!
下面是問卷星的js代碼
if (J[0].checked || J[1].checked) { alert('系統(tǒng)檢測(cè)到非法填寫問卷'); window.location.href = window.location.href; return; }
這里我直接屏蔽了驗(yàn)證函數(shù)
單選題直接用XPath查找填寫,random生成隨機(jī)數(shù)選擇選項(xiàng)
對(duì)于多選題,使用的是a標(biāo)簽與input綁定的方式,似乎是優(yōu)化過的,因?yàn)橹熬W(wǎng)上流傳的腳本都填不了多選了,這里我直接取出頁(yè)面中所有的a標(biāo)簽,如果當(dāng)前的a標(biāo)簽有rel屬性,并且下一個(gè)兄弟標(biāo)簽的type是checked,則認(rèn)定當(dāng)前標(biāo)簽為一個(gè)多選的選項(xiàng)
問卷星頁(yè)面的命名的一些規(guī)則,input的name為q+對(duì)應(yīng)的題目編號(hào),多選題是a標(biāo)簽跟input綁定,使用的是rel屬性,rel命名規(guī)則是:q+對(duì)應(yīng)的題目編號(hào)+選項(xiàng)編號(hào)
<li style="width:99%;"> <a href="javascript:" rel="external nofollow" class="jqCheckbox" rel="q2_2"></a> <input style="display:none;" id="q2_2" name="q2" value="2" type="checkbox"> <label>選項(xiàng)8</label> </li>
文本框是固定文字的。
總結(jié)
以上所述是小編給大家介紹的JS實(shí)現(xiàn)問卷星自動(dòng)填問卷腳本兩秒自動(dòng)提交功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
微信小程序錄音實(shí)現(xiàn)功能并上傳(使用node解析接收)
在我們的日常開發(fā)中經(jīng)常會(huì)遇到錄音功能,并上傳到服務(wù)器,今天小編給大家分享微信小程序錄音功能實(shí)現(xiàn)并上傳錄音文件,使用node解析接收,需要的朋友可以參考下2020-02-02javascript比較語(yǔ)義化版本號(hào)的實(shí)現(xiàn)代碼
這篇文章先是給大家簡(jiǎn)單的介紹了下語(yǔ)義化版本號(hào),而后再用實(shí)例代碼演示語(yǔ)義化版本號(hào)的比較方法,有需要的朋友們可以參考借鑒。2016-09-09JS基于Location實(shí)現(xiàn)訪問Url、重定向及刷新頁(yè)面的方法分析
這篇文章主要介紹了JS基于Location實(shí)現(xiàn)訪問Url、重定向及刷新頁(yè)面的方法,結(jié)合實(shí)例形式分析了javascript使用Location進(jìn)行URL訪問、重定向、頁(yè)面刷新等操作相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-12-12JavaScript 判斷指定字符串是否為有效數(shù)字
最近在做一個(gè)ColdFusion的項(xiàng)目,有一個(gè)業(yè)務(wù)Check,需要用JavaScript實(shí)現(xiàn):判斷指定字符串是否為有效數(shù)字。2010-05-05在?localStorage?中上傳和檢索存儲(chǔ)圖像的示例詳解
這篇文章主要介紹了在?localStorage?中上傳和檢索存儲(chǔ)圖像,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06JS實(shí)現(xiàn)的隨機(jī)排序功能算法示例
這篇文章主要介紹了JS實(shí)現(xiàn)的隨機(jī)排序功能算法,結(jié)合具體實(shí)例形式分析了javascript常用的排序算法實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-06-06js實(shí)現(xiàn)滾動(dòng)條滾動(dòng)到某個(gè)位置便自動(dòng)定位某個(gè)tr
這篇文章主要介紹了js實(shí)現(xiàn)滾動(dòng)條滾動(dòng)到某個(gè)位置便自動(dòng)定位某個(gè)tr的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01JavaScript 中有關(guān)數(shù)組對(duì)象的方法(詳解)
下面小編就為大家?guī)硪黄狫avaScript 中有關(guān)數(shù)組對(duì)象的方法(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08