亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

【譯】使用自定義ViewHelper來簡化Asp.net MVC view的開發------part5(完)

2019-11-17 03:53:28
字體:
來源:轉載
供稿:網友
   接上文..前面我們已經創建好了HtmlFieldSet,現在,為了讓HtmlHelper的擴展方法可以使用這個類,還需要創建一個方法:NewHtmlFieldSet

public static IViewObject NewHtmlFieldSet(
    this HtmlHelper htmlhelper, string name, string title, object attributes)
{
    IViewObject viewObject = new HtmlFieldSet(
        new ViewRequestContext(htmlhelper), name, title, attributes);
    viewObject.StartView();
    return viewObject;
}     這個方法的實現和前面所提到的那些沒有上面不同,都是傳入相應參數并返回view object,在View被初始化時返回這個對象,View首先在初始化時使用返回的View object,更確切點說,返回的IViewObject會在using語句中被view使用,例子如下:

<% using (Html.NewHtmlFieldset("FieldsetName", "My Fieldset", null))
   { %>
    <li>
      <label for="FirstName">FirstName</label>
      <span id="FirstName"><%= Html.Encode(Model.FirstName) %></span>  
    </li>
<% } %>     對應生成的HTML代碼如下:

<fieldset name="FieldsetName">
  <legend>My Fieldset</legend>
  <ol>
      <li>
        <label for="FirstName">FirstName</label>
        <span id="FirstName">Sayed</span>  
      </li>
  </ol>
</fieldset>
EndView方法輸出了最后的三個結尾標簽(</li>,</ol>,</fieldset>),達到了我們的預期,現在就可以使用view helper來創建fieldset以及包含在內的legend,以便達到更好的可理解和可維護性。下面來看view helper是如何簡化view的開發的。

這篇文章中附帶的示例代碼時全功能版本,每一個頁面都有兩個版本-使用view helper和不使用view helper.不適用view helper的版本全部手動創建HTML,而使用view helper的版本包括了我們先前創建的3個view helper,讓我們來進行簡單的比較,從源碼中找到AddContactClassic.aspx

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master"  
  Inherits="System.Web.Mvc.ViewPage<Sedodream.Web.ViewHelper.Models.AddContactModel>"
%>

<%@ Import Namespace="Sedodream.Web.Common.Contact" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
  Add Contact Classic
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
  <h2>Add Contact Classic</h2>
  <%= Html.ValidationSummary("Errors exist") %>
   
  <ol>     <li>
      <span class="success-message"><%= ViewData["SuccessMessage"]%></span>
      </li>
  </ol>
  <% using (Html.BeginForm())
     { %>
      <fieldset>
        <legend>Account Information</legend>
        <ol>
          <li>
            <label for="FirstName">First name</label>
            <%= Html.TextBox("FirstName") %>
            <%= Html.ValidationMessage("FirstName", "*") %>
          </li>
          <li>
            <label for="LastName">Last name</label>
            <%= Html.TextBox("LastName") %>
            <%= Html.ValidationMessage("LastName", "*") %>
          </li>
          <li>
            <label for="Email">Email</label>
            <%= Html.TextBox("Email")%>
            <%= Html.ValidationMessage("Email", "*")%>
          </li>
          <li>
            <label for="Phone">Phone</label>
            <%= Html.TextBox("Phone")%>
            <%= Html.ValidationMessage("Phone", "*")%>
          </li>
          <li>
            <div class="option-group" id="GenderContainer">
              <label for="Gender">Gender</label>
              <% foreach (SelectListItem item in Model.GenderList)
                 { %>
                   <%= Html.RadioButton(item.Text, item.Value)%>
                   <span><%= item.Text%></span>
              <% } %>
            </div>
          </li>
           
          <li>
            <input type="submit" value="Add contact" />
          </li>
        </ol>
      </fieldset>
  <% } %>
</asp:Content> 上面代碼盡管簡單,但仍然包含多達59行代碼,而且看起來十分丑陋,下面的版本是使用我們自定義的view helper,讓我們來看看包含在AddContactNew.aspx內的新版本:

<%@ Page
Inherits="System.Web.Mvc.ViewPage<Sedodream.Web.ViewHelper.Models.AddContactModel>"
    Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Title="" %>

<%@ Import Namespace="Sedodream.Web.Common.View" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
  Add Contact New
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

    <h2>Add Contact New</h2>
     
    <%= Html.ValidationSummary("Errors exist") %>
     
    <ol>
      <li>
        <span class="success-message"><%= Model.SuccessMessage %></span>
      </li>
    </ol>
    <% using (Html.BeginForm())
       { %>
    <fieldset>
        <legend>Account Information</legend>
        <ol>
            <% Html.NewText("FirstName", "First name"); %>
            <% Html.NewText("LastName", "Last name"); %>
            <% Html.NewText("Email", "Email"); %>
            <% Html.NewText("Phone", "Phone"); %>
            <% Html.NewRadioButtonGroup("Gender", Model.GenderList); %>
             
            <li>
                <input type="submit" value="Add contact" />
            </li>
        </ol>
     
    </fieldset>
    <% } %>
</asp:Content>  


使用view helper的版本html大大減少(只有39行)而且更容易理解,這里需要注意view引入了Sedodream.Web.Common.View命名空間,這使view helper擴展方法所必須的.Sedodream.Web.Common.View命名空間包含在另一個程序集中,這樣更方便你在整個小組內進行分發,使用View helper所帶來的可理解性只是使用它所帶來好處的其中之一,它還會帶來以下好處:

View更清爽,更容易理解
小組內遵循某些標準更容易
在修改時需要改變的地方更少
可利用回傳的model state輔助生成代碼
在前面我們提到了GetModelStateValue方法的使用。這個方法用于給HTML元素賦上它自己從View里回傳的值,而在view helper內可以給生成的html元素賦值.下面代碼片段是System.Web.Mvc.Html.InputExtensions源文件中的一部分,這里用來展示GetModelStateValue的用法:

case InputType.Radio:
    if (!usedModelState) {
        string modelStateValue = htmlHelper.GetModelStateValue(
            name, typeof(string)) as string;
        if (modelStateValue != null) {
            isChecked = String.Equals(
                modelStateValue, valueParameter, StringComparison.Ordinal);
            usedModelState = true;
        }
    } 上面代碼先檢查model state來看radio button是否被創建,如果radio button已經存在就可以查看radio button是否已經被選中,當你創建自定義view helper時,你最好也在合適的地方支持類似(可以獲取當前html的元素)的功能。前面的HtmlText view helper已經說明了這一點。



文章到此已經將創建自定義view helper的方方面面都講到了。



    

-------------------------------------------

shit live writer把part4給覆蓋了沒有保存,找時間我重新翻譯

全文完

原文鏈接:http://mvcviewhelpers.codeplex.com/

translated by CareySon

2 1 0
您已投過票
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人性色生活仑片| 亚洲一区二区免费| 高跟丝袜欧美一区| 精品视频久久久久久久| 亚洲qvod图片区电影| 精品久久久久久久中文字幕| 97成人精品视频在线观看| 中文字幕精品久久| 91色视频在线导航| 欧美丰满片xxx777| 欧美成人午夜激情在线| 日韩免费在线观看视频| 97在线视频国产| 亚洲 日韩 国产第一| 欧美日韩高清区| 欧美色播在线播放| 欧美高清激情视频| 91在线观看免费高清完整版在线观看| 成人福利视频在线观看| 成人黄色午夜影院| 一本久久综合亚洲鲁鲁| 亚洲性线免费观看视频成熟| 国产美女久久精品香蕉69| 九九热精品视频| 亚洲国产91精品在线观看| 日本精品视频在线| 国产精品久久久久77777| 久久久久久久久国产| 97视频在线观看免费高清完整版在线观看| 国产综合色香蕉精品| 国产精品美女在线| 97婷婷大伊香蕉精品视频| 亚洲肉体裸体xxxx137| 人人做人人澡人人爽欧美| 日本亚洲欧洲色| 欧美性精品220| 午夜精品蜜臀一区二区三区免费| 国产精品欧美日韩| www国产亚洲精品久久网站| 91在线高清视频| 热久久美女精品天天吊色| 日本成人精品在线| 秋霞成人午夜鲁丝一区二区三区| 欧美黄色三级网站| 亚洲电影免费观看高清完整版| 久久精品国产亚洲7777| 亚洲天堂男人天堂| 久久亚洲精品小早川怜子66| 亚洲男女性事视频| 亚洲国产精品yw在线观看| 欧美成人剧情片在线观看| 欧美夫妻性生活视频| 欧美—级高清免费播放| 久久综合免费视频影院| 精品成人69xx.xyz| 国产精品pans私拍| 国产精品嫩草视频| 在线观看日韩专区| 高清在线视频日韩欧美| 97成人精品视频在线观看| 欧美又大粗又爽又黄大片视频| 久久久久久久999| 中文字幕精品久久| 欧美精品在线免费播放| 中日韩午夜理伦电影免费| 91精品国产综合久久香蕉922| 亚洲天堂av网| 91精品久久久久久久| 欧美成人免费视频| 亚洲人成电影网站色| 国产精品久久久久久久app| 国产亚洲视频中文字幕视频| 国产精品第一视频| 色琪琪综合男人的天堂aⅴ视频| 最近中文字幕mv在线一区二区三区四区| 色偷偷av亚洲男人的天堂| 欧美精品久久久久久久久| 国产精品青青在线观看爽香蕉| 日韩www在线| 91久久久久久久| 精品丝袜一区二区三区| 成人精品视频在线| 久久久久一本一区二区青青蜜月| 综合欧美国产视频二区| 亚洲国产精品嫩草影院久久| 国产一区二区三区三区在线观看| 一本大道香蕉久在线播放29| 亚洲国产精品久久久久秋霞不卡| 日韩视频在线免费| 日韩欧美精品网站| 57pao成人永久免费视频| 一本色道久久88亚洲综合88| 91国产高清在线| 亚洲美女av网站| 久久久久久久久久久成人| 日韩在线视频网| 欧美日韩国内自拍| 日本欧美一级片| 91成品人片a无限观看| 久久久久久国产精品三级玉女聊斋| 少妇av一区二区三区| 黄色一区二区在线| 91九色精品视频| 国产亚洲激情在线| 亚洲精品www久久久久久广东| 伊人伊人伊人久久| 97在线免费观看视频| 庆余年2免费日韩剧观看大牛| 青草成人免费视频| 奇米4444一区二区三区| 成人国产精品色哟哟| 久久免费福利视频| 国产免费一区二区三区在线能观看| 隔壁老王国产在线精品| 久久全球大尺度高清视频| 久久精品国产清自在天天线| 欧美又大又粗又长| 久久夜色精品国产欧美乱| 亚洲欧美精品suv| 欧洲日韩成人av| 欧美老肥婆性猛交视频| 亚洲免费av片| 欧美性猛交xxxxx免费看| 69久久夜色精品国产69乱青草| 中文字幕自拍vr一区二区三区| 九九综合九九综合| 欧美成人免费在线视频| 国产自摸综合网| 国产91精品久久久| 欧美一级免费视频| 久久精品久久久久| 97超碰国产精品女人人人爽| 国产精品美女在线| 中文字幕不卡在线视频极品| 日韩av在线免费观看一区| 日韩电影视频免费| 日韩美女视频中文字幕| 九色精品美女在线| 欧洲午夜精品久久久| 91久久久国产精品| 伊人av综合网| 2021久久精品国产99国产精品| 亚洲成年人影院在线| 美日韩精品免费观看视频| 中文字幕亚洲欧美日韩高清| 国产精品美女主播在线观看纯欲| 欧美激情网站在线观看| 欧美人在线观看| 精品久久久久久中文字幕一区奶水| 亚洲老头老太hd| 亚洲国产日韩一区| 成人中文字幕+乱码+中文字幕| 成人在线观看视频网站| 亚洲va欧美va在线观看| 欧美资源在线观看| 法国裸体一区二区| 欧美最猛性xxxxx亚洲精品| 国内精品美女av在线播放| 国产69精品久久久| 久久影视电视剧免费网站清宫辞电视| 欧美日韩性视频| 国产成人精品最新| www.亚洲一二| 欧美第一页在线|