2

我正在为机械师写一个检查清单,所以一切都使用单选按钮和下拉菜单(废话!)。可能有超过 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 的新手和脚本新手,所以请原谅我的无知。我希望有人对我的问题有一个简单的解决方案,我也尝试了全局变量,但要么我没有正确格式化它,要么它也不起作用。谢谢阅读!

4

2 回答 2

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 即可,该请求对我来说效果很好。

但是已经给出的答案也将起作用,所以我正在敲它,但我发现我遇到了问题,并用这种对我有用的方法调整了原始答案。

希望这可以帮助

于 2014-01-03T22:31:19.200 回答
0

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

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

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

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

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

于 2013-11-04T16:20:38.160 回答