Webmatrix中Response.Redirect的替代方案

时间:2013-03-26 13:38:59

标签: forms variables webmatrix response.redirect

我正在为机械师写一份清单,所以一切都使用单选按钮和下拉菜单(等等!)。可能有超过50个项目,因此在URL中传递值将是混乱的。如果我使用POST发送表单,则传递所有变量值,但是我需要使用Response.Redirect来获取表单以写入数据库并阻止变量传递到下一页。我尝试过META刷新和Response.StatusCode = 307;但到目前为止没有任何作用这是第一页......

@{

var UNITNO = "";
var DATE = DateTime.Now;
var MECHANIC = "";
var HEADLIGHTS = "";
var TailStopSignalHazard = "";

   if(IsPost)
   { 

UNITNO = Request.Form["UNITNO"];
MECHANIC = Request.Form["MECHANIC"];
HEADLIGHTS = Request.Form["HEADLIGHTS"];
TailStopSignalHazard = Request.Form["TailStopSignalHazard"];

    var db = Database.Open("MAINT");
    var insertCommand = "INSERT INTO CHECKLIST (UNITNO, DATE, MECHANIC, HEADLIGHTS, TailStopSignalHazard) Values(@0, @1, @2, @3 ,@4)";
    db.Execute(insertCommand, UNITNO, DATE, MECHANIC, HEADLIGHTS, TailStopSignalHazard);
    Response.StatusCode = 307;
    Response.Redirect("list.cshtml");
    //<META http-equiv="REFRESH" content="0; url=list.cshtml">    
}

<script type="text/javascript">
function validateForm() {
    var aa = document.getElementById("UNITNO");
    var ac = document.getElementById("MECHANIC");
    var xx = document.getElementsByName("HEADLIGHTS");
    var xz = document.getElementsByName("TailStopSignalHazard");

    if (aa.options[aa.selectedIndex].index == 0) { alert("Must enter Unit Number"); return false; }
    if (ac.options[ac.selectedIndex].index == 0) { alert("Must enter Mechanic"); return false; }
    if (xx[0].checked == false && xx[1].checked == false) { alert("Must enter Headlights"); return false; }
    if (xz[0].checked == false && xz[1].checked == false) { alert("Must enter Tail/Stop/Signal/Hazard"); return false; }
}
</script>
}


<!DOCTYPE html>
<html>

<head>
<meta charset="utf-8" />
    <title>Western Check List</title>
</head>

<body>

  <h1>Western Disposal</h1>
  <!-- <form method="post" onsubmit="return validateForm()" action="list.cshtml"> //-->
  <form method="post" onsubmit="return validateForm()">
  <fieldset>
  <legend>Check List</legend>
        &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp

        <script>
        date=Date()
        document.write(date)
        </script> 

<p>
        <label> Unit Number: </label> 
        <select name="UNITNO">
        <option value=""></option>
        <option value="108">108</option>
        <option value="110">110</option>
        <option value="111">111</option> 
        </select>  
 </p>


 <p>
        <label>Mechanic:</label>
        <select name="MECHANIC" >
        <option value=""></option>
        <option value="BOB">BOB</option>
        <option value="DANIEL">DANIEL</option>
        <option value="DOUG">DOUG</option>
        </select>
 </p>

 <p>
   <b>  LIGHTING:  </b>
 </br>
     <label>&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &rlm; &nbsp Head Lights:</label>
     <input type="RADIO"  name="HEADLIGHTS" value="GOOD"/>GOOD &nbsp &nbsp
     <input type="RADIO"  name="HEADLIGHTS" value="BAD"/>BAD

   </br>
     <label>&nbsp Tail/Stop/Signal/Hazard:</label>
     <input type="RADIO" name="TailStopSignalHazard" value="GOOD"/>GOOD &nbsp &nbsp
     <input type="RADIO" name="TailStopSignalHazard" value="BAD"/>BAD

 </p>

  <p><input type="submit" value="POST"/></p>
 </fieldset>
  </form>

 </body>

 </html>

然后我用第二页检查数据库和“UNITNO”的值......

   @{
var db=Database.Open("MAINT");
var grid=new WebGrid(db.Query("SELECT * FROM CHECKLIST ORDER BY ID"));
 }
 <!DOCTYPE html>
  <html>
  <head>
    <title>Western Check List Data Base</title>
    <style type="text/css">
        table {border-collapse:  collapse;}
        td, th {border:  solid 1px; }
    </style>
   </head>
    <body>
     <h1>Western Check List Data Base</h1>
    @grid.GetHtml()
    <a href="Default.cshtml">RETURN</a>
    &nbsp &nbsp &nbsp &nbsp the unit number was="@Request["UNITNO"]"
    </body>

      </html>

我是webmatrix的新手,也是脚本的新手所以请原谅我的无知。我的希望是有人对我的问题有一个简单的解决方案,我也尝试了全局变量,但要么我没有正确地格式化它,要么它也不起作用。谢谢你的阅读!

2 个答案:

答案 0 :(得分:0)

您可以将一些数据传递给重定向上的第二个脚本:

Response.Redirect("list.cshtml?UNITNO=" + Request.Form["UNITNO"]);

但是如果你需要发送大量数据,那可能会变得混乱。更好的方法是发送新创建的记录的数据库ID。然后,您可以在第二个脚本上再次打开它,并阅读并显示您喜欢的任何数据:

Response.Redirect("list.cshtml?id=" + db.GetLastInsertId());

我自己的一般规则是,如果我正在进行重定向并且需要维护数据,我应该考虑重构代码以便在可能的情况下不需要它 - 但上面的解决方案应该有效。

答案 1 :(得分:0)

尝试

Response.Redirect("list.cshtml/" + Request.Form["UNITNO"]);

我发现使用

Response.Redirect("list.cshtml?UNITNO=" + Request.Form["UNITNO"]);

确实有效,但是如果你在表单的开头使用var UNITNO,则URL将传递list.cshtml = UNITO xxx,无论UNITNO是什么,并不总是通过,具体取决于你如何获得表单中的URL var。

只需用简单替换?UNITNO /然后请求对我来说效果很好。

但是已经给出的答案也会有效,所以我敲了它但是我发现我遇到了问题并且用这种适合我的方法调整了原来的答案。

希望这有帮助