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

标签 javascript html forms redirect

这就是我想要实现的目标:我想创建一个带有表单的 HTML 页面,当您提交表单时,它会转到 4 个位置之一。有一个在页面加载时自动选择的默认隐藏主选项和 2 个可选子选项。

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

这是我到目前为止的代码:

<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.");
    }
}

关于javascript - 复选框选择时的表单重定向,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16478853/

相关文章:

javascript - 提高 jQuery 函数的效率

javascript - 不同时区不同设备上的 Unix 时间

javascript - 点击推文引用内容

html - 通过 CSS 处理大字符串、截断或隐藏的更优雅的方法是什么?

javascript - 在格式化网站的 javascript 编码选项卡中定位计时器创建的文本区域,该文本区域在计时器上重复

php - 使用 PHP 将查询转换为单选按钮以供选择

javascript - .html() 未在页面上填充 div 变回

javascript - 跨浏览器兼容打开新选项卡/窗口(浏览器)

Javascript 读取多维表单

Javascript/jQuery - 选择复选框之一时显示隐藏的#element