解析html帮助程序

本文关键字:帮助程序 html 解析 | 更新日期: 2023-09-27 18:20:46

我正在使用Razor引擎从数据库中动态编译我的剃刀视图。现在我使用Razor Engine 3.7.3。我很少看到关于如何阅读html助手并编译它的帖子,但它是为旧版本的Razor引擎发布的。

我读过ITemplateServiceConfiguration,但我也不太明白它是如何工作的。

我的问题是,如何在数据库的Html内容中使用@Html(Html助手)、@Url(Url助手)和@section(如@section脚本、@section特色)成功运行compile()razorengine(v3.7.3)

到目前为止我所做的事情。我试图实现我从另一篇文章中得到的代码。该代码适用于较旧版本的剃须刀引擎。他建议我们创建自己的助手类:

public class RazorHtmlHelper
{
    public IEncodedString Partial(string viewName)
    {
        ITemplate template = RazorEngine.Razor.Resolve(viewName);
        ExecuteContext ec = new ExecuteContext();
        RawString result = new RawString(template.Run(ec));
        return result;
    }
}
public class RazorUrlHelper
{
    public string Encode(string url)
    {
        return System.Uri.EscapeUriString(url);
    }
}

然后他建议创建我们自己的模板:

public class RazorTemplateBase<T> : TemplateBase<T>
{
    private RazorUrlHelper _urlHelper = new RazorUrlHelper();
    private RazorHtmlHelper _htmlHelper = new RazorHtmlHelper();
    public RazorUrlHelper Url
    {
        get
        {
            return this._urlHelper;
        }
    }
    public RazorHtmlHelper Html
    {
        get
        {
            return this._htmlHelper;
        }
    }
}

在解析之前,我们需要设置我们的配置:

Razor.SetTemplateService(new TemplateService( new TemplateServiceConfiguration()
{
    BaseTemplateType = typeof(RazorTemplateBase<>)
};
));
result = RazorEngine.Razor.Parse(templateText, model);

RazorUrlHelper没有问题,但RazorHtmlHelper无法正确读取这些代码,因为它已被弃用:

ITemplate template = RazorEngine.Razor.Resolve(viewName);
ExecuteContext ec = new ExecuteContext();
RawString result = new RawString(template.Run(ec));

上面的代码来自这篇文章

解析html帮助程序

我不完全确定我的建议是否能直接解决你的问题。根据我的专业经验,尝试利用不推荐使用的类不会产生积极的结果。我个人不会尝试直接从数据库中呈现视图。如果我在你的位置上利用MVC4的剃刀视图引擎,我会放弃你的方法,遵循以下步骤。

  1. 右键单击您的项目并使用nuget将MVC4和所有包含的js/dll/库更新到最新版本
  2. 创建包含变量的模型对象集,以容纳将从数据库中提取的所有信息。利用继承或设计它们,以便在每次请求的基础上有效地使用它们
  3. 为MVC项目构建主视图和局部视图,以最有效地防止任何重复的前端代码。如果这些视图主要返回HTML响应,请将控制器操作设置为指向应用程序主视图的ActionResult()。在这些控制器操作中,用数据库中所需的所有数据填充模型对象,并将填充的模型对象传递到主视图
  4. 在部分视图和主视图中,您可以将此模型对象定义为视图顶部的主模型,并将模型变量作为参数传递给HTMLHelpers
  5. 创建将这些模型变量作为参数的HTML Helper对象,并在Views/web.config文件中定义它们的命名空间。在本例中,我使用了命名空间System.Web.HtmlHelpers。如果不这样做,您将无法利用视图中基本命名空间之外的任何自定义帮助程序。

    <system.web.webPages.razor>
    <host factoryType="System.Web.Mvc.MvcWebRazorHostFactory, System.Web.Mvc, Version=5.2.3.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
      <pages pageBaseType="System.Web.Mvc.WebViewPage">
       <namespaces>
        <add namespace="System.Web.Mvc" />
        <add namespace="System.Web.Mvc.Ajax" />
        <add namespace="System.Web.Mvc.Html" />
        <add namespace="System.Web.Optimization"/>
        <add namespace="System.Web.Routing" />
        <add namespace="System.Web.HtmlHelpers" />
       </namespaces>
      </pages>
    </system.web.webPages.razor>
    
    1. 在您的HTMLHelpers命名空间类中,创建MVCHtmlString或其他MVC方法,这些方法接受您的数据库模型参数,并将它们转换为可工作和正常工作的HTML/JSON或XML。在部分视图和主视图中引用这些自定义HTML帮助程序

如果你以这种方式实现你的HTMLHelpers,你就用访问数据并将结构化数据库数据转换为可查看HTML的逻辑抽象掉了JIT编译的代码(所有视图代码)。在上面的示例中,您将在运行时JIT编译视图的大部分逻辑,这在性能方面非常昂贵。MVC是这样设计的,这样你就可以避免承担所有的开销。如果您在预编译的库中创建了强大的HTML帮助程序,那么您可以使视图代码变得非常小和简单。