2

MVCの前は、Webフォームだけがあったとき、私は自分のコントロール(呼び出すことができるボックス)のコンテナーを定義し、他のコントロールでこのWebコントロール(タイトル、本文、およびその他のいくつかのプロパティを含む)を使用していました。

したがって、すべてのビジュアルコントロールの外観を変更したい場合は、Boxコントロールを1つ変更するだけで済みます。

これは、私が以前行っていたことの簡略化されたスニペットです。

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="Box.ascx.cs" Inherits="WebApp.Controls.Box" %>
<span class="boxtitle">
    <asp:Literal ID="ltrTitle" runat="server"></asp:Literal>
</span>
<div class="boxContent" id="dvBox">
    <asp:PlaceHolder runat="server" ID="BoxBodyContainer"/>
</div>

そしてコードビハインド:

public Control BoxBody { get; set; }
public string Title
{
    get { return this.ltrTitle.Text; }
    set { this.ltrTitle.Text = value; }
}
protected void Page_Load(object sender, EventArgs e)
{
    this.BoxBodyContainer.Controls.Add(this.BoxBody);
}  

したがって、これを自分のページの他のコントロールと一緒に次のように使用できます。

<MyControls:Box ID="Box1" Title="Foo" runat="server">
    <boxbody>
        <MyControls:CustomControl ID="Bar" runat="server" >
         </MyControls:CustomControl>
    </boxbody>
</MyControls:Box>  

MVC 3で同じようなものを使用するには、Boxビューを定義し、ボックスが必要な場所ですべてのデータ(タイトル、ボックスボディなど)を使用するHtml.Partialか、このビューに渡してボックスビューで使用する必要があると思います。 しかし、これを達成するためのより良い、より標準的な方法があるかどうか疑問に思いました。MVC 3(Razor)でこれを達成する正しい方法は何ですか? Html.Action@Html.Raw

4

1 に答える 1

3

これを行うには、HtmlHelper拡張メソッドを作成できます。私が見つけた最高のチュートリアルはMVC2用でしたが、それはあなたに基本を与えます。

チュートリアルでカバーされていないのはSystem.Web.MVC、コードでhtmlを作成するのに役立つクラスが名前空間にあるということです。

注:次のコードはテストされていません。

using System;
using System.Web.Mvc;

public static class HtmlExtensions
{
    public static MvcHtmlString Box(this HtmlHelper helper, string title, MvcHtmlString body)
    {
        TagBuilder span = new TagBuilder("span");
        span.AddCssClass("boxtitle");
        span.SetInnerText(title.ToString());

        TagBuilder div = new TabBuilder("div");
        div.AddCssClass("boxContent");
        div.InnerHtml = body;

        return MvcHtmlString.Create(span.ToString() + div.ToString());
    }
}

このメソッドは、次のようにかみそりのビューから呼び出すことができます。

@Html.Box("foo", Html.Partial("bar"))
于 2012-04-10T01:35:16.040 に答える