ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript はアンケートに自動的に記入して送信するメソッドを実装します。

JavaScript はアンケートに自動的に記入して送信するメソッドを実装します。

巴扎黑
巴扎黑オリジナル
2018-05-12 11:20:106390ブラウズ

この記事では主にアンケートスター自動記入アンケートスクリプトの2秒自動送信機能のJS実装を紹介します

スクリプトはアンケートスターのみを使用しています。現在、任意の数のオプションを選択できます。 ! ! ! ! ! !

最近、多くのグループがアンケートのリンクを投稿して助けを求めているのを見かけました。たまたま過去 2 日間タスクがなかったので、アンケートに自動的に記入するスクリプトを作成してみました。同様のスクリプトが既に公開されています。オンラインですが、後にアンケートのスターが追加され、多肢選択式の質問は適用されなくなりました

スクリプトの使用方法 (例として Firefox):

1: マウスを空白に移動します。ブラウザのアドレス バーの下にスペースを置き、右クリックして新しいブックマークを作成します

2: 名前 (任意) を入力し、コードをアドレス バーにコピーします

3: Questionnaire Star 接続を開き、次に追加したブックマークをクリックします。

コード:

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(&#39;//input[(@type="radio") and not(@value="0") and @name="&#39; + i + &#39;"]&#39;, 
     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);

以前は、ページ上の入力タグを直接トラバースすると、非表示の多肢選択質問が追加されました。 validate 関数が実行されるとエラーが報告され、アンケートへの不正な記入を促します。 ! ! !

以下はQuestionnaire Starのjsコードです

​​
if (J[0].checked || J[1].checked) { 
 alert(&#39;系统检测到非法填写问卷&#39;); 
 window.location.href = window.location.href; 
 return; 
}

ここでは検証機能を直接ブロックしました

単一選択の質問はXPathを使用して直接入力され、randomは乱数の選択オプションを生成します

多肢選択の質問については、 a タグと input を使用します。以前インターネット上で流通していたスクリプトでは複数の選択を埋めることができなかったので、ここでは現在の a タグが rel 属性を持つ場合に、ページ内のすべての a タグを直接取り出します。 、次の兄弟タグには、 type がチェックされている場合、現在のラベルは複数選択オプションとみなされます
アンケートのスター ページの名前付けルールは、q + 対応する質問番号です。 -choice 質問は、rel 属性を使用して a タグと入力にバインドされます。rel 命名規則は次のとおりです: q+対応する質問番号+オプション番号

<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>选项8</label> 
</li>

テキスト ボックスには固定テキストがあります。

以上がJavaScript はアンケートに自動的に記入して送信するメソッドを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。