加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – 带有淘汰赛的EditorFor HTML Helper

发布时间:2020-12-16 03:28:28 所属栏目:asp.Net 来源:网络整理
导读:我认为有一个扩展版本是非常有用的 EditorFor HTML帮助程序,它自动为Knockout JS写出值数据绑定. 这将是客户端视图模型和服务器端视图模型相同的地方 – 我已经通过使用ko映射并通过AJAX获取viewmodel来自动生成客户端视图模型. 有没有其他人尝试这样的事情,
我认为有一个扩展版本是非常有用的
EditorFor HTML帮助程序,它自动为Knockout JS写出值数据绑定.

这将是客户端视图模型和服务器端视图模型相同的地方 – 我已经通过使用ko映射并通过AJAX获取viewmodel来自动生成客户端视图模型.

有没有其他人尝试这样的事情,或者是否有任何项目包括类似于我在这里的想法?

这样做的好处是,在重构时,不会有错过数据绑定值的危险.

解决方法

我们已经沿着这些方向做了一些事情,它远非完美,我们在自定义扩展中有更多,但我提取了精华.

using System.Web.Mvc.Html;

namespace System.Web.Mvc
{
    public static class EditorForExtensions
    {
        public static MvcHtmlString TextBoxForViewModel<TModel,TProperty>(this HtmlHelper<TModel> htmlHelper,Expression<Func<TModel,TProperty>> expression)
        {
            ModelMetadata metadata = ModelMetadata.FromLambdaExpression(expression,htmlHelper.ViewData);

            var htmlAttributes = HtmlAttributesForKnockout(metadata);

            return htmlHelper.TextBoxFor(expression,htmlAttributes);
        }

       private static Dictionary<string,object> HtmlAttributesForKnockout(ModelMetadata metadata)
        {
            var htmlAttributes = new Dictionary<string,object>();

            var knockoutParameter = String.Format("value: {0}",metadata.PropertyName);

            htmlAttributes.Add("data-bind",knockoutParameter);

            return htmlAttributes;
        }
    }
}

然后可以使用它:

@Html.TextBoxForViewModel(m => m.Name)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读