Creating reusable HTML view components using Razor in ASP.NET MVC

前端 未结 2 1505
悲&欢浪女
悲&欢浪女 2020-12-13 00:26

I have a Razor helper function that creates a re-usable HTML panel that saves me writing the same HTML over and over again.

@helper DefaultPanel(string panel         


        
相关标签:
2条回答
  • 2020-12-13 00:53

    There are two ways to achieve the required functionality.

    1. @helper

    Create @helper which accepts whatever parameters you need plus a function (single object parameter, returns object):

    @helper DefaultPanel(string panelTitle, Func<object, object> content)
    {
        <div class="panel">
            <div class="panel-logo">
                    <img src="/logo.png" />
                </div>
                <div class="panel-inner">
                    <p class="panel-title">@panelTitle</p>
                    <div class="panel-content">
                        @content(null)
                    </div>
                </div>
        </div>
    }
    

    Usage:

    @DefaultPanel("title",
    @<div class="panel-content-inner">
        <p>Welcome back, please select from the following options</p>
        <a href="#">Profile</a>
        <a href="#">My Defails</a>
    </div>
    )
    

    Your function may also accepts parameters, example here.

    2. HtmlHelper extension method

    Add the following code anywhere in your project:

    namespace System.Web.Mvc
    {
        public static class HtmlHelperExtensions
        {
            public static HtmlDefaultPanel DefaultPanel(this HtmlHelper html, string title)
            {
                html.ViewContext.Writer.Write(
                "<div class=\"panel\">" +
                "<div class=\"panel-inner\">" +
                "<p class=\"panel-title\">" + title + "</p>" +
                "<div class=\"panel-content\">"
                );
    
                return new HtmlDefaultPanel(html.ViewContext);
            }
        }
    
        public class HtmlDefaultPanel : IDisposable
        {
            private readonly ViewContext _viewContext;
            public HtmlDefaultPanel(ViewContext viewContext)
            {
                _viewContext = viewContext;
            }
            public void Dispose()
            {
                _viewContext.Writer.Write(
                "</div>" +
                "</div>" +
                "</div>"
                );
            }
        }
    }
    

    Usage:

    @using (Html.DefaultPanel("title2"))
    {
        <div class="panel-content-inner">
            <p>Welcome back, please select from the following options</p>
            <a href="#">Profile</a>
            <a href="#">My Defails</a>
        </div>
    }
    

    The extension method writes directly to the context. The trick is to return a disposable object, which Dispose method will be executed at the end of using block.

    0 讨论(0)
  • 2020-12-13 00:54

    I don't know if @helper methods can do this but HtmlHelper extensions certainly can. You've mentioned the Html.BeginForm() example which is probably the most well known - all that does is return an object which implements IDisposable which means that when the Dispose() method is called it just calls the complimentary Html.EndForm() method to add the appropriate closing tags.

    It would be very simple to do something similar for your HTML code. You can view the source code to the ASP.NET MVC HtmlHelpers at http://aspnetwebstack.codeplex.com/ - the BeginForm() code can be specifically be viewed here.

    0 讨论(0)
提交回复
热议问题