我正在尝试限制SharePoint 2010列表中允许的条目数。该列表供用户注册,我们希望将其限制为60例如。我看过类似的问题,但似乎都没有。
迄今为止发现的验证公式都不合适。我将不胜感激任何建议和帮助。
谢谢你提前! :)
答案 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文档。