asp.net-mvc-3 – Orchard CMS DataAnnotations – 客户端验证
我试图让一个不明显的客户端验证工作在一个果园模块,但我遇到了一个问题. 在这个例子中,我只是试图使用Html.TextBoxFor()强制在一个文本框字段上的RequiredAttribute. 它看起来像是由Orchard(LocalizedModelValidatorProvider)实现的自定义ModelValidatorProvider防止HTML5输入属性被渲染,具体来说: data-val data-val-required 对于标准的DataAnnotations RequiredAttribute.这些属性是jQuery.validate.unobtrusive工作所必需的. LocalizedModelValidatorProvider将RequiredAttribute映射到LocalizedRequiredAttribute,因此在为使用LocalizedRequiredAttribute装饰的模型属性呈现文本框输入时,Orchard ViewEngine中可能还会出现一个错误(或未实现的功能)? 我怀疑这不会发生: tagBuilder.MergeAttributes(htmlHelper.GetUnobtrusiveValidationAttributes(name,metadata)); (来自System.Web.Mvc.Html.InputExtensions) 我目前正在运行Orchard 1.3.9. 注意:一个棘手的解决方法是删除OrchardStarter模块中LocalizedModelValidatorProvider的注册,并将其默认返回到标准MVC 3提供程序,尽管如果可能,我很想打扰Orchard源代码(更不要说我可能需要本地化某些消息)… 解决方法我花了3个星期来解决在MyPrettyCMS对话框中使用的无阻碍的验证问题.我也使用LocalizedRequiredAttribute,你可以看到那些AutoGenerated MetaDataModels. 我不知道Orcad,但我认为它像JQuery对话框一样呈现用户表单. 有两个困难: 第一步:您必须(重新)将对话框字段附加到用于将数据发送到服务器的表单. 第二:您必须(重新)解析表单以获得有效的无条件验证 你可以在这里找到一个完整的JQuery Dialog based Form,使用无阻碍的验证,并重点关注$.validator.unobtrusive.parse(form); 在JQuery common tool box中查看$.fn.jqDialogFunction $.fn.jqDialogFunction = function (idDiv,titre,okFunction,openFunction) { var dialogBox = $(idDiv) //$(dialogBox).removeClass("notDisplayed"); $(dialogBox).hide(); $(dialogBox).dialog({ title: titre,autoOpen: false,resizable: false,modal: true,minHeight: 450,minWidth: 800,open: openFunction,buttons: [ { text: "Ok",click: okFunction },{ text: "Cancel",click: function () { $(this).dialog("close"); } } ] }); var form = dialogBox.find("form"); if (form != null) { $.validator.unobtrusive.parse(form); } $(idDiv).dialog('open'); } 然后查看方法$.fn.SaveContent – > $(“#divStructurePage”).parent().appendTo(form); $.fn.SaveContent = function () { $(this).dialog("close"); var content = tinyMCE.activeEditor.getContent(); $("#hidNewContent").val(content); var v = $("#StructurePage_FK_LayoutMenu_Translation").val(); var form = $("#frmManagedContent"); $("#divStructurePage").parent().appendTo(form); form.attr("action","/"+ $("#hidControllerName").val() +"/Save/" + v); form.submit(); } (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net – IControllerFactory’MyWebSite.WebUI.Infrastr
- VS 2013 RC中缺少ASP.NET Web窗体脚手架功能
- asp.net Web.config 详细配置说明
- asp.net – 允许服务器/ usercontrol上的任何属性/属性
- asp.net-mvc – 使用html.actionlink将模型从视图传递到控制
- 如何刷新#include文件 – 它们在IIS7 / ASP.NET上进行缓存
- asp.net中利用Jquery+Ajax+Json实现无刷新分页的实例代码
- asp.net – WebBrowsable vs个性化Web部件
- .NET WebApi jsonapi.org支持
- ASP.NET 2.0 JQuery AJAX登录
- ASP.NET MVC 4 JSON绑定到视图模型 – 嵌套对象错
- asp.net – 按钮属性: – commandName和Command
- asp.net – 实体框架CTP5,代码优先.可选的导航属
- asp.net – 在Web.config帮助中定义tagPrefixes
- asp.net-core – 如何在Visual Studio 2015 RC中
- asp.net – 我应该在.gitingore文件中包含.vs文件
- 集成ASP.NET Webforms,WebAPI和AngularJS
- asp.net – 防止XSS(跨站脚本)
- 模型 – 视图 – 控制器 – ASP.NET WebForms vs
- asp.net中Session缓存与Cache缓存的区别分析