這篇文章將為大家詳細講解有關JS如何實現問卷星自動填寫腳本和自動提交功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
腳本只使用問卷星,多選題目前為選中任意選項數量?。。。。。?!
最近看到很多群里都在發問卷連接,各種求幫忙,正好這兩天沒任務,嘗試寫了自動填問卷的腳本,類似的腳本網上已經有了,但是后來問卷星加了驗證,并且多選題已經不能適用
腳本使用方式(以Firefox為例):
一:鼠標移動到瀏覽器地址欄下空白處,右鍵,新建書簽
二:填寫名稱(任意),代碼復制到地址欄中
三:打開問卷星連接,然后點擊剛剛添加的書簽,即可。
代碼:
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);
之前問卷星的前端加入了一個隱藏的選擇題,如果直接遍歷頁面上的input標簽,會把這道題一起做了,然后validate函數執行的時候會報錯,提示非法填問卷?。。?!
下面是問卷星的js代碼
if (J[0].checked || J[1].checked) { alert('系統檢測到非法填寫問卷'); window.location.href = window.location.href; return; }
這里我直接屏蔽了驗證函數
單選題直接用XPath查找填寫,random生成隨機數選擇選項
對于多選題,使用的是a標簽與input綁定的方式,似乎是優化過的,因為之前網上流傳的腳本都填不了多選了,這里我直接取出頁面中所有的a標簽,如果當前的a標簽有rel屬性,并且下一個兄弟標簽的type是checked,則認定當前標簽為一個多選的選項
問卷星頁面的命名的一些規則,input的name為q+對應的題目編號,多選題是a標簽跟input綁定,使用的是rel屬性,rel命名規則是:q+對應的題目編號+選項編號
<li > <a href="javascript:" rel="external nofollow" class="jqCheckbox" rel="q2_2"></a> <input id="q2_2" name="q2" value="2" type="checkbox"> <label>選項8</label> </li>
文本框是固定文字的。
關于JS如何實現問卷星自動填寫腳本和自動提交功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。