微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – 默认情况下,Html.TextArea会生成额外的换行符

我正在渲染这样一个普通的textarea:

@Html.TextAreaFor(x => x.Description)

我希望看到一个空的textarea,但这是我所看到的(我选择第一行使其更清晰):

我检查了生成的html,它包含开始和结束标记间的换行符:

<textarea class="form-control" cols="20" id="Description" name="Description" rows="2">
</textarea>

这是通过设计完成的吗?我可以改变这种行为吗?

解决方法

在看到你的问题之后,我研究了Google,看看@ Html.TextAreaFor中额外行背后的问题是什么.看一看.

有些文章与您的问题有关: –

http://www.peschuster.de/2011/11/new-line-bug-in-asp-net-mvcs-textarea-helper/

ASP.NET MVC Textarea HTML helper adding lines when using AntiXssLibrary

文章提出了TextAreaHelper类中的基本问题,它由@ Html.TextAreaFor使用.

private static MvcHtmlString TextAreaHelper(HtmlHelper htmlHelper,ModelMetadata modelMetadata,string name,IDictionary<string,object> rowsAndColumns,object> htmlAttributes)
{
    // Some initialization here...

    TagBuilder tagBuilder = new TagBuilder("textarea");

    // Some more logic...

    tagBuilder.SetInnerText(Environment.NewLine + attemptedValue);
    return tagBuilder.ToMvcHtmlString(TagRenderMode.normal);
}

以上代码中的问题是

tagBuilder.SetInnerText(Environment.NewLine + attemptedValue);

这就是为什么@ Html.TextAreaFor的实际输出会是这样的,额外的行显示

<textarea>&#13;&#10;This is the content...</textarea>

这个问题的解决方法

第一种解决方法实现Javascript onLoad修复以从所有textareas中删除有问题的编码:

$("textarea").each(function () { $(this).val($(this).val().trim()); });

第2种解决方法创建自己的帮助程序,以在视图中呈现textarea标记

public static MvcHtmlString FixedTextAreaFor<TModel,TProperty>(
  this HtmlHelper<TModel> htmlHelper,Expression<Func<TModel,TProperty>> expression)
{
    return new MvcHtmlString(htmlHelper.TextAreaFor(expression)
        .ToHtmlString()
        .Replace(">&#13;&#10;",">" + Environment.NewLine));
}

这些文章还建议在MVC 4 Developer Preview中修复此问题!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐