【问题标题】:Displaying HTML from a Database by using MVC 3 (ASPX ViewModel)使用 MVC 3 (ASPX ViewModel) 显示数据库中的 HTML
【发布时间】:2010-11-03 00:48:16
【问题描述】:

我在存储和显示来自我的 SQL 数据库的数据时使用 MVC 3(ASPX ViewModel)。我尝试使用原始输入来存储它以及使用 HttpUtility.HtmlEncode。当我尝试显示时,两者都不起作用。我尝试过使用 HttpUtility.HtmlDecode 以及使用<%: Model.MyHtmlVariable %>。我错过了什么吗?

【问题讨论】:

  • “不工作”通常是对问题的错误描述。您应该发布一些代码,因为您尝试的所有 3 种技术都应该在该页面上显示一些内容。
  • 我认为很明显我没有得到 HTML。标题确实说显示来自数据库的 HTML。
  • 嗯,这对我来说并不明显。乍一看,这看起来像 MyHtmlVariable 根本没有填充。想想“输出编码的 HTML”与“不工作”有多清晰。
  • 很公平。感谢建设性的批评。 :)

标签: asp.net-mvc viewmodel asp.net-mvc-3 asp.net-mvc-views


【解决方案1】:

使用传统的“”语法应该会为您呈现它,但可能并不取决于您在做什么。如果没有,请尝试将其包装在 HtmlString 对象中,如下所示:

MVC 应该尊重并正确渲染它。

如果您只是想显示编码的 HTML,“” 语法是您的朋友

【讨论】:

  • 谢谢杰西!此外,有人指出使用返回 IHtmlString 的方法来保持内联代码的一致性。
【解决方案2】:

您需要创建一个 div 来定位并使用对控制器操作的 jquery/javascript 调用来设置 html。

jQuery.get("/Controller/Action", 
     function(response) {  
          $("#MyDiv").html(response) 
     });  

看看类似的方法是否有效。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-11
    • 1970-01-01
    相关资源
    最近更新 更多