gpt4 book ai didi

asp.net-mvc - 如何在MVC中的Controller中获取下拉值

转载 作者:行者123 更新时间:2023-12-04 02:47:42 25 4
gpt4 key购买 nike

我使用递归函数使用字符串列表绑定(bind)下拉列表
我的下拉菜单有这样的值(value)家首页>> 厨房首页>> 厨房>> ABC

我想在数据库中使用相同的下拉值 ABC

这是我的查看代码

@{
ViewBag.Title = "Createnewproduct";
}
<h2>
Create new product</h2>
<div>
@using (Html.BeginForm("Createnewproduct", "ProductAdmin", FormMethod.Post, new { id = "sendFileForm", enctype = "multipart/form-data" }))
{
<table>
<tr>
<td>
Category
</td>
<td>
@Html.DropDownList("Test", new SelectList(ViewBag.ListOfDisciplines, Model))
</td>
</tr>
<tr>
<td>
Product Name
</td>
<td>
<input type="text" name="ProductName">
</td>
</tr>
<tr>
<td>
Product Description
</td>
<td>
<input type="text" name="ProductDescription">
</td>
</tr>
<tr>
<td>
Product long Description
</td>
<td>
<input type="text" name=" ProductlongDescription">
</td>
</tr>
<tr>
<td>
UPC
</td>
<td>
<input type="text" name="UPC">
</td>
</tr>
<tr>
<td>
SKU
</td>
<td>
<input type="text" name="SKU">
</td>
</tr>
<tr>
<td>
Stock
</td>
<td>
<input type="text" name="Stock">
</td>
</tr>
<tr>
<td>
Weight
</td>
<td>
<input type="text" name="Weight">
</td>
</tr>
<tr>
<td>
Height
</td>
<td>
<input type="text" name="Height">
</td>
</tr>
<tr>
<td>
Image URL
</td>
<td>
<input type="file" name="file" id="file" style="width: 100%;" id="Imageupload" />
</td>
</tr>
<tr>
<td rowspan="2">
<input type="submit" value="Save" />
</td>
</tr>
</table>
}
</div>

我的 Controller 是这样的

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Createnewproduct(FormCollection form)
{

}

当我在那里看到我的 FormCollection 值时,我没有找到下拉值,所有其他值都在 FormCollection 中正确找到

请帮我看看我在这段代码中哪里做错了


 public ActionResult Createnewproduct()
{
List<Category> categorylist = _Listofcategory();
var parentcate = categorylist.Where(c => c.ParentCategoryId == 1).ToList();
List<String> categoryList = new List<string>();
string prefix = ">>";
foreach (var item in parentcate)
{
prefix = item.CategoryName;
Setchild(prefix, item, categorylist, categoryList);


}

ViewBag.ListOfDisciplines = categoryList;
return View();
}


private void Setchild(string prefix, Category model, List<Category> listcategory, List<string> catStrings)
{
var childs = listcategory.Where(x => x.ParentCategoryId == model.CategoryId).ToList();

catStrings.Add(prefix);
if (childs.Count > 0)
{

foreach (var child in childs)
{
catStrings.Add(prefix + ">>" + child.CategoryName);
var subchild = listcategory.Where(c => c.ParentCategoryId == child.CategoryId).ToList();
if (subchild.Count > 0)
{
foreach (var subsubchild in subchild)
{
catStrings.Add(prefix + ">>" + child.CategoryName + ">>" + subsubchild.CategoryName);

var subsubsubchild = listcategory.Where(c => c.ParentCategoryId == subsubchild.CategoryId).ToList();
if (subsubsubchild.Count > 0)
{
foreach (var subsubsubsubchild in subsubsubchild)
{
catStrings.Add(prefix + ">>" + child.CategoryName + ">>" + subsubchild.CategoryName + ">>" + subsubsubsubchild.CategoryName);
}
}
}
}


}

}

}

这是我的类别列表如何在 View 模型中使用。

请告诉我

最佳答案

您也可以针对您的场景使用下面提到的示例代码。这里我使用了 ViewModel。

领域模型:

 public class Product
{
public Product() { Id = Guid.NewGuid(); Created = DateTime.Now; }
public Guid Id { get; set; }
public string ProductName { get; set; }

public virtual ProductCategory ProductCategory { get; set; }
}

public class ProductCategory
{
public int Id { get; set; }
public string CategoryName { get; set; }

public virtual ICollection<Product> Products { get; set; }
}

查看模型:

public class ProductViewModel
{
public Guid Id { get; set; }

[Required(ErrorMessage = "required")]
public string ProductName { get; set; }

public int SelectedValue { get; set; }

public virtual ProductCategory ProductCategory { get; set; }

[DisplayName("Product Category")]
public virtual ICollection<ProductCategory> ProductCategories { get; set; }
}

操作方法:

 [HttpGet]
public ActionResult AddProduct() //generate view with categories for enter product data
{
//for get product categories from database
var prodcutCategories = Repository.GetAllProductCategories();

//for initialize viewmodel
var productViewModel = new ProductViewModel();

//assign values for viewmodel
productViewModel.ProductCategories = prodcutCategories;

//send viewmodel into UI (View)
return View("AddProduct", productViewModel);
}

[HttpPost]
public ActionResult AddProduct(ProductViewModel productViewModel) //save entered data
{
//get product category for selected drop down list value
var prodcutCategory = Repository.GetProductCategory(productViewModel.SelectedValue);

//for get all product categories
var prodcutCategories = Repository.GetAllProductCategories();

//for fill the drop down list when validation fails
productViewModel.ProductCategories = prodcutCategories;

//for initialize Product domain model
var productObj = new Product
{
ProductName = productViewModel.ProductName,
ProductCategory = prodcutCategory,
};

if (ModelState.IsValid) //check for any validation errors
{
//save recived data into database
Repository.AddProduct(productObj);
return RedirectToAction("AddProduct");
}
else
{
//when validation failed return viewmodel back to UI (View)
return View(productViewModel);
}
}

View :

@model YourProject.ViewModels.ProductViewModel        //set your viewmodel here

<div class="boxedForm">

@using (Html.BeginAbsoluteRouteForm("add", new { action = "AddProduct"},FormMethod.Post }))
{
<ul>
<li style="width: 370px">
@Html.LabelFor(m => m.ProductCategories)
@Html.DropDownListFor(m => m.SelectedValue,new SelectList(Model.ProductCategories, "Id",
"CategoryName"),"-Please select a category -")
@Html.ValidationMessageFor(m => m.ProductCategory.Id)
</li>
<li style="width: 370px">
@Html.CompleteEditorFor(m => m.ProductName, labelOverride: "Product Name")
@Html.ValidationMessageFor(m => m.ProductName)
</li>
</ul>
<div class="action">
<button class="actionButton" type="submit">
<span>Save</span></button>
</div>
}
</div>

最终输出

enter image description here

关于asp.net-mvc - 如何在MVC中的Controller中获取下拉值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18548039/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com