复选框选择时的表单重定向

Form redirect on checkbox selection

本文关键字:表单 重定向 选择 复选框      更新时间:2023-09-26

这是我想要实现的:我想创建一个HTML页面的表单,当你提交的表单去4个位置之一。有一个默认的隐藏主选项是在页面加载时自动选择的,还有两个可选的子选项。

哦,它会计算选择的金额!

下面是目前为止的代码:
<html>
<head></head>
<body>
<form onSubmit="submitForm();" id="myForm" type="get">
<input id="myCheckbox1" name="myCheckbox1" type="checkbox" value="20" onClick="calcNow();" />Default option<br/>
<input id="myCheckbox2" name="myCheckbox2" type="checkbox" value="30" onClick="calcNow();" />Add-on option 1<br/>
<input id="myCheckbox2" name="myCheckbox2" type="checkbox" value="40" onClick="calcNow();" />Add-on option 2<br/>
<input id="myTotal" name="myTotal" type="text" value="" disabled="disabled" /><br/>
<input type="button" id="myButton" onClick="submitForm();" value="Continue" />
</form>
<script type="text/javascript">
var pages = [[["http://mysite.com/page1.html"],["http://mysite.com/page2.html"],["http://mysite.com/page3.html","http://mysite.com/page4.html"]]];
function calcNow()
{
    var cb = document.getElementById("myCheckbox1");
    var cb = document.getElementById("myCheckbox2");
    var cost1 = cb.checked ? parseInt(cb.value) : 0;
    var cost2 = cb.checked ? parseInt(cb.value) : 0;
    var costTotal = cost1 + cost2;
    document.getElementById("myTotal").value = costTotal;
    var op1 = cb.checked ? 1 : 0;
    if (op1 != undefined)
    {
        return pages[op1];
    }
    return undefined;
}
function submitForm()
{
    var page = calcNow();
    if (page != undefined)
    {
        alert(page);
        // ---- To navigate ----
        //location.href = page;
        // ---- To alter post ----
        //var form = document.getElementById("myForm");
        //form.action = page;
        //form.submit();
    }
    else
    {
        alert("Please answer all questions.");
    }
}
function getRadioValue(name)
{
  var controls = document.getElementsByName(name);
  for (var i = 0; i < controls.length; i++) {
      if (controls[i].checked) {
          return parseInt(controls[i].value);
      }
  }
  return 0;
}
function getRadioData(name, attribute)
{
  var controls = document.getElementsByName(name);
  for (var i = 0; i < controls.length; i++) {
      if (controls[i].checked) {
          return parseInt(controls[i].dataset[attribute]);
      }
  }
  return undefined;
}
</script>
</body>
</html>

试试这个

编辑:

function submitForm()
{
    //The code goes inside here, you have to decide where to redirect from if or the else 
    window.location.assign("http://www.w3schools.com/");   
    var page = calcNow();
    if (page != undefined)
    {
        alert(page);
    }
    else
    {
        alert("Please answer all questions.");
    }
}