下拉列表和单选按钮在 MVC 4 中验证失败后处于选定状态
本文关键字:失败 于选定 状态 验证 单选按钮 MVC 下拉列表 | 更新日期: 2023-09-27 18:33:13
我以单一形式使用Dropdownlist,Radiobutton,Textbox
和Radio Buttons
。我使用了RequiredIF
验证器。当我提交时,验证器可以工作,但 dropdowmlist 和单选按钮状态会改变。我需要在提交后不更改所选值。该怎么做?
我的代码是。
视图:
@*DropDownlist*@
<select id="Cust_Id" name="Cust_Id" class="dropdownlist"> </select>
@*RadioButton*@
<input name="Pay_Mode1" value="false" onclick="chMd()" type="radio"
checked="checked" />Cash <input name="Pay_Mode1" onclick="chMd()"
type="radio" value="true" />Cheque
@*Grid*@
<div id="divgrid" style="margin-top: 15px;">
@{
var grid = new WebGrid(Model, canPage: true, rowsPerPage: 5, selectionFieldName: "selectedRow",
ajaxUpdateContainerId: "gridContent");
grid.Pager(WebGridPagerModes.NextPrevious);}
<div id="gridContent">
@grid.GetHtml(
tableStyle: "webgrid-table",
headerStyle: "webgrid-header",
footerStyle: "webgrid-footer",
alternatingRowStyle: "webgrid-alternating-row",
selectedRowStyle: "webgrid-selected-row",
rowStyle: "webgrid-row-style",
columns: grid.Columns(
grid.Column("Id", "ID", style: "id"),
grid.Column("Cust_Name", "Cust Name", style: "PName"),
grid.Column("Pay_Amount", "Pay_Amount", style: "ICode"),
grid.Column("Pay_Mode", "Pay_Mode", style: "IName"),
grid.Column("Bank_Name", "Bank_Name", style: "Weight"),
grid.Column("Bank_Address", " Bank_Address", style: "MakingCharge"),
grid.Column("ChequeNo", "ChequeNo", style: "Certification"),
grid.Column("Cheque_Date", " Cheque_Date", style: "Price"),
grid.Column(header: "Delete", format: @<text><a href="@Url.Action("DeleteReceipt", "Admin", new { Id
= item.ID })" onclick="javascript:return confirm('Are you sure you'd like to delete this product?');"><img
src="../Images/delete.png" alt='Delete' /></a></text>)
))
@if (grid.HasSelection)
{
Receipt = (JewellaryWeb.Models.Receipt)grid.Rows[grid.SelectedIndex].Value;
<b>Id</b> @Receipt.Id<br />
<b>Code</b> @Receipt.Cust_Name<br />
<b>Item_Code</b> @Receipt.Pay_Amount<br />
<b>Item_Name</b> @Receipt.Pay_Mode<br />
<b>Weight</b> @Receipt.Bank_Name<br />
<b>Making_Charge</b> @Receipt.Bank_Address<br />
<b>Certification</b> @Receipt.ChequeNo<br />
<b>Price</b> @Receipt.Cheque_Date<br />
}
</div>
Controller:
[HttpPost]
public ActionResult ReceiptMaster(Receipt model, string command)
{
Receipt Receipt = new Models.Receipt();
if (command == "Sumbit")
{
int Id = 0;
if (model.Pay_Mode == "C")
{
model.ChequeNo = "";
model.Cheque_Date = ("1/1/1753 12:00:00 AM");
model.Bank_Name = "";
model.Bank_Address = "";
}
if (ModelState.IsValid)
{
Id = Receipt.SaveReceipt(model.Id, model.Cust_Id, model.Pay_Amount, model.Pay_Mode, model.Bank_Name, model.Bank_Address, model.ChequeNo, model.Cheque_Date);
if (Id > 0)
{
ViewData["Success"] = "Product was saved successfully.";
ViewData["ControlView"] = 1;
//ObservableCollection<Receipt> ReceiptList = new ObservableCollection<Receipt>();
model.ReceiptList = Receipt.GetReceiptList();// model.ReceiptList is your model property
return View(model.ReceiptList);
}
// ObservableCollection<Receipt> ReceiptList = new ObservableCollection<Receipt>();
model.ReceiptList = Receipt.GetReceiptList();// model.ReceiptList is your model property
return View(model.ReceiptList);
}
model.ReceiptList = Receipt.GetReceiptList();// model.ReceiptList is your model property
return View(model.ReceiptList);
//ObservableCollection<Receipt> ReceiptList = new ObservableCollection<Receipt>();
//ReceiptList = Receipt.GetReceiptList();
//return View(ReceiptList);
}
//ObservableCollection<Receipt> ReceiptList = new ObservableCollection<Receipt>();
model.ReceiptList = Receipt.GetReceiptList();// model.ReceiptList is your model property
return View(model.ReceiptList);
}
型:
public ObservableCollection<Receipt> ReceiptList { get; set; }
DataAccessLayer objDAL = new DataAccessLayer();
[DisplayFormat(ConvertEmptyStringToNull = false)]
public Int32 Id { get; set; }
[Required(ErrorMessage = "Please Select the Name")]
public Int32 Cust_Id { get; set; }
public string Name { get; set; }
public string Cust_Name { get; set; }
public string Date { get; set; }
[Required(ErrorMessage = "*")]
[StringLength(10, ErrorMessage = "Maximum {1} characters exceeded")]
[RegularExpression(@"[0-9]*'.?[0-9]+", ErrorMessage = "{0} must be a Number.")]
public string Pay_Amount { get; set; }
[StringLength(10, ErrorMessage = "Maximum {1} characters exceeded")]
public string Credit { get; set; }
[StringLength(10, ErrorMessage = "Maximum {1} characters exceeded")]
public string Pay_Mode { get; set; }
public bool Pay_Mode1 { get; set; }
public bool IsChequeRequired
{
get
{
return Pay_Mode1;
}
}
[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must enter Bank Name !")]
[StringLength(10, ErrorMessage = "Maximum {1} characters exceeded")]
public string Bank_Name { get; set; }
[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must enter Bank Address !")]
//[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must explain any '"Yes'" answers!")]
[StringLength(20, ErrorMessage = "Maximum {1} characters exceeded")]
public string Bank_Address { get; set; }
//[Required(ErrorMessage = "*")]
[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must enter ChequeNo !")]
[StringLength(20, ErrorMessage = "Maximum {1} characters exceeded")]
public string ChequeNo { get; set; }
// [Required(ErrorMessage = "*")]
[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must enter Cheque Date !")]
[StringLength(10, ErrorMessage = "Maximum {1} characters exceeded")]
public string Cheque_Date { get; set; }
//[RequiredIf("IsChequeRequired", true, ErrorMessage = "You must enter Cheque Date !")]
//[StringLength(20, ErrorMessage = "Maximum {1} characters exceeded")]
public string Credited { get; set; }
public SelectList Ddl { get; set; }
public List<SelectListItem> SelectedValue { get; set; }
DataTable dt = new DataTable();
我通过使用Viewdata()
和Script
以及对View的一些修改来做到这一点...我修改后的代码是
Controller:
ViewData["PAYMODE"] = model.Pay_Mode;
ViewData["Credit"] = model.Credited;
ViewData["CustName"] = model.Cust_Name;
In View:
Script
<script type="text/javascript">
$(document).ready(function () {
var val = ('@ViewData["PAYMODE"]');
var Credit = ('@ViewData["Credit"]');
if (val == "C") {
document.getElementById("Cash").checked = true;
chMd();
} else {
document.getElementById("Cheque").checked = true;
chMd();
}
if (Credit == "N") {
document.getElementById("CreditNo").checked = true;
chMd1();
}
else {
document.getElementById("CreditYes").checked = true;
chMd1();
}
});
</script>
Design:
<input name="dOption1" id="CreditYes" value="Y" onclick="chMd1()" type="radio" />Yes
<input name="dOption1" id="CreditNo" value="N" onclick="chMd1()" type="radio" checked="checked"/>No
<input name="Credited" type="text" style="visibility: hidden; width: 1px;" value="n" />