簡體   English   中英

獲取單選按鈕的選定值onclick的提交並將值傳遞給函數

[英]get selected value of radio button onclick of submit and pass value to a function

我正在用PHP做一些工作。 我有兩個php頁面

index.php

<html>
<head>
<script>
function getVote(int)
{
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("poll").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","poll-vote.php?vote="+int,true);
xmlhttp.send();
}
</script>
</head>
<body>
<h3>Is this correct? </h3>
<div id="poll">

<form>
Yes:
<input type="radio" name="vote" value="0">
<br>No:
<input type="radio" name="vote" value="1">
<input type="submit" value="Forward" onclick="getVote(value);"> 
</form>
</div>
</body>
</html>

在單擊提交按鈕時,我需要獲取所選單選按鈕的值並將其傳遞給函數。

請幫我

在您的onclick內聯函數中僅調用一個函數...

 <input type="submit" value="Forward" onclick="getVote();"> //here

並在您的函數中獲取檢查的單選值。

var radiovalue= $('input[name="vote"]:checked').val()

嘗試這個

JAVASCRIPT

function getVote()
{
 var radiovalue= $('input[name="vote"]:checked').val()
 if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
    xmlhttp=new XMLHttpRequest();
  }
 else
 {// code for IE6, IE5
    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
 }
 xmlhttp.onreadystatechange=function()
{

 if (xmlhttp.readyState==4 && xmlhttp.status==200)
  {
   document.getElementById("poll").innerHTML=xmlhttp.responseText;
  }
}
xmlhttp.open("GET","poll-vote.php?vote="+radiovalue,true);
xmlhttp.send();
}

的HTML

<input type="submit" value="Forward" onclick="getVote();"> 

提供動作和方法屬性以首先形成

<form action="index.php" method="post">

不僅如此,您還可以獲得如下所示的值:

$vote = $_POST['vote'];

我希望這是您要尋找的。

嘗試:

function getVote()
{
    var int=document.getElementById("vote").value;
    ....

編輯:注意到這是一個無線電輸入...所以這行不通。 您需要類似:

function getRadioCheckedValue(radio_name)
{
   var oRadio = document.forms[0].elements[radio_name];

   for(var i = 0; i < oRadio.length; i++)
   {
      if(oRadio[i].checked)
      {
         return oRadio[i].value;
      }
   }

   return '';
}

然后執行:

function getVote()
{
    var int=getRadioCheckedValue(vote);
    ....

通過jquery,您可以像下面這樣獲取所選電台的值:

$('input[name=vote]:checked').val()

嘗試更改那些2:

<form name="myForm"> 

onclick="getValue(document.myForm);"

然后函數:

function getValue(form){
 var value = '';
 for (var i = 0; i < form.elements.length; i++ ) {
   if (form.elements[i].type == 'radio') {
         if(form.elements[i].checked == true) {
             value = form.elements[i].value;
        }
     }
   }

if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("poll").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","poll-vote.php?vote="+value,true);
xmlhttp.send();
}

調用沒有任何值的函數,然后像這樣讀出函數之間的單選按鈕:

var rval = document.getElementsByName('vote');

for (var i = 0, length = rval.length; i < length; i++) {
    if (rval[i].checked) {
        alert(rval[i].value); // your value
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM