电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

ASP.NET MVC擴展帶驗證的單選按鈕

瀏覽:69日期:2022-06-08 18:56:00

在ASP.NET MVC4中,HtmlHelper為我們提供了Html.RadioButton()方法用來顯示Radio Button單選按鈕。如果想顯示一組單選按鈕,通常的做法是遍歷一個集合把每個單選按鈕顯示出來。本篇嘗試寫一個擴展方法用來展示一組帶驗證的單選按鈕。

首先來擴展HtmlHelper,擴展方法中接收一個SelectListItem的集合,遍歷這個集合把每個單選按鈕顯示出來,并且讓這些單選按鈕具有不同的id屬性值。

using System.Collections.Generic;using System.Linq.Expressions;using System.Text;using System.Web.Mvc.Html;namespace System.Web.Mvc{    public static class HtmlExtensions     {public static MvcHtmlString RadioButtonListFor<TModel, TProperty>(this HtmlHelper<TModel> htmlHelper,     Expression<Func<TModel, TProperty>> expression, IEnumerable<SelectListItem> list){    //獲取元數據    var metaData = ModelMetadata.FromLambdaExpression(expression, htmlHelper.ViewData);    var sb = new StringBuilder();    if (list != null)    {foreach (var item in list) {    //把屬性名和集合元素的Value值拼接作為元素的id    var id = string.Format("{0}_{1}", metaData.PropertyName, item.Value);    //創建單選按鈕    var label = htmlHelper.Label(id, HttpUtility.HtmlEncode(item.Text));    var radio = htmlHelper.RadioButtonFor(expression, item.Value, new {id = id}).ToHtmlString();    sb.AppendFormat("<div class=\"RadioButton\">{0}{1}</div>", radio, label); }    }    return MvcHtmlString.Create(sb.ToString());}    }}

假設,現在有一個View Model,其中的一個屬性要求必須。

using System.ComponentModel.DataAnnotations;namespace MvcApplication1.Models{    public class Vm    {[Required(ErrorMessage = "必填")]public int CityId { get; set; }    }}

以下City類的集合將作為所有Radio Button的數據源。

namespace MvcApplication1.Models{    public class City    {public int Id { get; set; }public string Name { get; set; }    }}

在HomeController中,提供一個Action方法啊,把City的集合轉換成SelectListItem集合傳遞給視圖。

using System.Collections.Generic;using System.Linq;using System.Web.Mvc;using MvcApplication1.Models;namespace MvcApplication1.Controllers{    public class HomeController : Controller    {public ActionResult Index(){    List<City> cities = new List<City>()    {new City(){Id = 1, Name = "青島"},new City(){Id = 2, Name = "濟南"},new City(){Id = 3, Name = "平度"}    };    ViewData["c"] = from c in citiesselect new SelectListItem() {Text = c.Name, Value = c.Id.ToString()};    return View(new Vm());}[HttpPost]public ActionResult Index(Vm vm){    if (ModelState.IsValid)    {return Content(vm.CityId.ToString());    }    else    {return View(vm);    }}    }}

在_Layout.csthml中,必須具備客戶端驗證js。

<head>    <meta charset="utf-8" />    <meta name="viewport" content="width=device-width" />    <title>@ViewBag.Title</title>    @Styles.Render("~/Content/css")    @Scripts.Render("~/bundles/jquery")    @Scripts.Render("~/bundles/jqueryval")</head><body>    @RenderBody()        @RenderSection("scripts", required: false)</body>

在Home/Index.chtml中,使用擴展方法顯示Radio Button組。

@model MvcApplication1.Models.Vm@{    ViewBag.Title = "Index";    Layout = "~/Views/Shared/_Layout.cshtml";}<style type="text/css">        .RadioButton { float:left; }</style>@using (Html.BeginForm("Index", "Home", FormMethod.Post, new {id = "addForm"})){    @Html.RadioButtonListFor(v => v.CityId, ViewData["c"] as IEnumerable<SelectListItem>)    @Html.ValidationMessageFor(v => v.CityId)        <input type="submit" value="提交"/>}

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
主站蜘蛛池模板: Jaeaiot捷易科技-英伟达AI显卡模组/GPU整机服务器供应商 | 盘扣式脚手架-附着式升降脚手架-移动脚手架,专ye承包服务商 - 苏州安踏脚手架工程有限公司 | 螺杆式冷水机-低温冷水机厂家-冷冻机-风冷式-水冷式冷水机-上海祝松机械有限公司 | 防爆暖风机_防爆电暖器_防爆电暖风机_防爆电热油汀_南阳市中通智能科技集团有限公司 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 全屋整木定制-橱柜,家具定制-四川峨眉山龙马木业有限公司 | LOGO设计_品牌设计_VI设计 - 特创易 | 细石混凝土泵_厂家_价格-烟台九达机械有限公司 | 锂辉石检测仪器,水泥成分快速分析仪-湘潭宇科分析仪器有限公司 | 镀锌角钢_槽钢_扁钢_圆钢_方矩管厂家_镀锌花纹板-海邦钢铁(天津)有限公司 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 | 中山市派格家具有限公司【官网】 | 洁净棚-洁净工作棚-无菌室-净化工程公司_北京卫护科技有限公司 | 小型高低温循环试验箱-可程式高低温湿热交变试验箱-东莞市拓德环境测试设备有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 国际金融网_每日财经新资讯网 | 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 模型公司_模型制作_沙盘模型报价-中国模型网 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 能量回馈_制动单元_电梯节能_能耗制动_深圳市合兴加能科技有限公司 | 健康管理师报名入口,2025年健康管理师考试时间信息网-网站首页 塑料造粒机「厂家直销」-莱州鑫瑞迪机械有限公司 | 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 单电机制砂机,BHS制砂机,制沙机设备,制砂机价格-正升制砂机厂家 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 安德建奇火花机-阿奇夏米尔慢走丝|高维|发那科-北京杰森柏汇 | 缠膜机|缠绕包装机|无纺布包装机-济南达伦特机械设备有限公司 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 手术室净化厂家-成都做医院净化工程的公司-四川华锐-15年特殊科室建设经验 | 集菌仪_智能集菌仪_全封闭集菌仪_无菌检查集菌仪厂家-那艾 | 涂层测厚仪_漆膜仪_光学透过率仪_十大创新厂家-果欧电子科技公司 | 游泳池设备安装工程_恒温泳池设备_儿童游泳池设备厂家_游泳池水处理设备-东莞市君达泳池设备有限公司 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 硬齿面减速机[型号全],ZQ减速机-淄博久增机械| 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 精益专家 - 设备管理软件|HSE管理系统|设备管理系统|EHS安全管理系统 | 电磁铁_小型推拉电磁铁_电磁阀厂家-深圳市宗泰电机有限公司 | 网站建设,北京网站建设,北京网站建设公司,网站系统开发,北京网站制作公司,响应式网站,做网站公司,海淀做网站,朝阳做网站,昌平做网站,建站公司 | 浙江美尔凯特智能厨卫股份有限公司 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 |