如何限制可以在SharePoint列表中输入的项目数?

时间:2016-04-22 14:06:49

标签: sharepoint sharepoint-2010 sharepoint-list

我正在尝试限制SharePoint 2010列表中允许的条目数。该列表供用户注册,我们希望将其限制为60例如。我看过类似的问题,但似乎都没有。

迄今为止发现的验证公式都不合适。我将不胜感激任何建议和帮助。

谢谢你提前! :)

1 个答案:

答案 0 :(得分:0)

没有任何内置功能可以帮助您实现这一目标。但是,如果您提供自己的界面来创建条目(例如自定义注册页面),则可以控制行为并在达到限制后阻止注册。

为了帮助您入门,以下是使用JavaScript对象模型查询列表并在创建项目之前检测项目计数的示例。

<input type="button" value="Sign Up Now!" onclick="createItemIfBelowLimit()" />
<script>
function createItemIfBelowLimit(){
    var max = 60;
    var listTitle = "Your List Title";
    var clientContext = new SP.ClientContext();
    var list = clientContext.get_web().get_lists().getByTitle(listTitle);
    clientContext.load(list);
    clientContext.executeQueryAsync(function(){
        var itemCount = list.get_itemCount();
        if(itemCount < max){
            createItem(listTitle,{
                "Title":"Example title text",
                "Body":"Example body text"
                });         
        }else{
            alert("This sign-up list is full. Sorry!");
        }
    },function(sender,args){
        alert(args.get_message());
    });
}
function createItem(listTitle,values){
    var clientContext = new SP.ClientContext();
    var list = clientContext.get_web().get_lists().getByTitle(listTitle);
    var newItem = list.addItem();
    for(var key in values){
        newItem.set_item(key,values[key]);
    }
    newItem.update();
    clientContext.load(newItem);
    var rootFolder = list.get_rootFolder(); // Note: use a list's root folder to determine its server relative URL
    clientContext.load(rootFolder);
    clientContext.executeQueryAsync(function(){
        var itemId = newItem.get_item("ID");
        SP.UI.ModalDialog.showModalDialog(
            { 
                title: "Item #"+itemId+" Created Successfully!", 
                url: rootFolder.get_serverRelativeUrl() + "/DispForm.aspx?ID="+itemId
            }
        ); 
    },function(sender,args){
        alert(args.get_message());
    });
}
</script>

要使用上述代码,请先将其保存到文本文件,然后将其上载到SharePoint网站上的库中。然后,您可以在站点上创建页面,向页面添加内容编辑器Web部件,以及编辑该内容编辑器Web部件的Web部件属性。在&#34;内容链接&#34;属性,粘贴到文本文件的链接;这将导致Web部件呈现您的HTML和JavaScript。

如需进一步阅读,请查看Microsoft提供的Common Programming Tasks in the JavaScript Object Model文档。