0

我正在使用 SharePoint 2010 并有一个自定义的 newform.aspx 和 editform.aspx,由于表单的字段数量和长度,我正在使用 JQuery 创建多个选项卡。

我遇到的问题之一是如何在用户尝试保存表单但未在某些(或所有必填字段)中输入值时以视觉方式向用户提供建议。我正在使用 SharePoint 中的 OOTB 验证功能来指示需要处理哪些字段,但是由于许多必填字段现在位于不同的选项卡上,我想弹出一个警报窗口,指示在保存之前需要处理哪些必填字段表格。

通常我只会处理两个或三个必填字段,但在这种情况下,我将处理八个必填字段,甚至可能更多。在过去,我会使用 JavaScript if else 语句执行以下操作:

 function PreSaveAction() {
    var tbTitle = getTagFromIdentifierAndTitle("input", "TextField", "Title");
    var tbVisitor = getTagFromIdentifierAndTitle("input", "TextField", "Visitor"); {
        if (tbTitle.value == "" && tbVisitor.value == "") {
            alert(tbTitle.title + ' is a required field' + '\n' + tbVisitor.title + ' is a required field');
            return true;
        } else {
            if (tbTitle.value == "") {
                alert(tbTitle.title + ' is a required field');
                return true;
            } else {
                if (tbVisitor.value == "") {
                    alert(tbVisitor.title + ' is a required field');
                    return true;
                } else {
                    return true;
                }
            }
        }
    }
}
function getTagFromIdentifierAndTitle(tagName, identifier, title) {
    var len = identifier.length;
    var tags = document.getElementsByTagName(tagName);
    for (var i = 0; i < tags.length; i++) {
        var tempString = tags[i].id;
        if (tags[i].title == title && (identifier == "" || tempString.indexOf(identifier) == tempString.length - len)) {
            return tags[i];
        }
    }
    return null;
}

由于我有这么多必填字段要处理,我知道多个嵌套的 if else 语句不是最有效的完成方式。将使用开关盒是要走的路吗?可能循环?我将如何去做(我不太精通 JavaScript)?

我在这里先向您的帮助表示感谢!

4

1 回答 1

1

您不需要嵌套语句。只需一次浏览一个字段即可构建警报,然后触发它:

var alertString="";

if (tbTitle.value == "") {  
    alertString+= tbTitle.title + ' is a required field' + '\n';  
}
if (tbVisitor.value == "") {  
    alertString+= tbVisitor.title + ' is a required field' + '\n';  
}
...
// After going through all fields:
if (alertString) {alert(alertString);}
于 2012-06-08T04:29:52.253 回答