1

我有一个 AccordionPanes 集合,其中包含各种 TextBox 控件和 DropDownLists,每个控件都有自己的验证器。

如果在表单提交时发生了一些服务器端验证,是否有一些东西可以自动展开包含无效验证器消息的先前最小化的窗格?否则,在用户看来,表单不能无故提交。

另一种情况:假设我有多个窗格,其中客户端验证器与输入相关联。如果窗格被最小化(因此您看不到验证器的 ErrorMessage),是否有办法在提交时发生 AJAX 页面验证时展开相应的窗格?

我知道这种方法有一种蛮力的方式,我跟踪每个验证器及其相关的 AccordionPane,但我希望有一个更好的解决方案来处理我的大量输入/验证器和窗格的情况。

4

3 回答 3

3

像这样的东西怎么样(使用JQuery,但我确信它可以转换成普通的javascript)......

$(document).ready(function(){
    if (isPostback()){
        $.each(Page_Validators, function(index, validator) {
            if (!validator.isvalid) {
            // do something here to locate the accordion based on the validator
            // $(this) is the currently invalid validator element as a jquery object/wrapped set
            // so for example...
                $(this).parent().slideDown();
            // This assumes that the immediate parent of of the validator is the accordion which is unlikely but if you post your emitted html I can write the appropriate selector for you.  
            }
        });
    }
});

因为您不希望它在初始加载时触发,您可以使用类似How to detect/track postback in javascript? 并检查您是否在 document.ready 之后进行回发 - 我假设您已使用链接中的建议,并且您的回发检测函数称为 isPostback()。

于 2012-10-08T13:46:51.543 回答
1

Rich 打败了我,但这是香草 js 版本(ie9+):

Page_Validators
    .filter(function(v) { return !v.isvalid; })
    .forEach(function (v) { console.log(v.parentNode); });

请记住将代码放在 </form>-tag 下方。我在使用 jQuerys document.ready 和 window.onload 时遇到了问题,因为它可能会在加载来自 asp.net 的所有需要​​的 JavaScript 之前执行代码。

更新:更兼容浏览器的版本

for(var i = 0; i < Page_Validators.length; i++) {
    var validator = Page_Validators[i];
    if (!validator.isvalid) {
        console.log(validator.parentNode);
    }
}
于 2012-10-08T13:56:14.007 回答
1

有一个为此问题构建的项目尝试查看它....您也可以下载源代码以分析更多详细信息或使用相同的代码库如果您愿意.... http://www.codeproject .com/Articles/43397/Validating-Accordion-and-RadPanelBar-using-Ajax-an

于 2012-10-08T17:42:17.080 回答