首页 > 解决方案 > Sharepoint 下拉选择过滤器

问题描述

我在表格上有一个下拉菜单。我将其设置为列表的唯一条目。这很好用,当用户选择已在先前列表条目中选择的选项时,他们会在保存或提交表单时收到通知。但是,如果该选择已经做出并存在于列表中,我宁愿从下拉列表中删除该选择,这样他们就无法选择已经选择的内容。谢谢你的帮助

标签: filtersharepoint-2013dropdowninfopath2010

解决方案


我们可以使用 REST API 来获取所有存在的下拉项,然后在新建/编辑表单页面中删除下拉选项。以下代码供您参考。

<script src="//code.jquery.com/jquery-3.3.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
    removeDuplicateDropDowm("FilterDropDown");
});
function removeDuplicateDropDowm(fieldName){
    var listId = _spPageContextInfo.pageListId.replace("{","").replace("}","");
    var fieldHTML="";
    var url = _spPageContextInfo.webAbsoluteUrl + "/_api/web/lists(guid'"+listId+"')/items?$select="+fieldName;
    $.ajax({
        url: url,
        method: "GET",
        async:false,
        headers: { "Accept": "application/json; odata=verbose" },
        success: function (data) {       
            var items = data.d.results;
            $("select[title='"+fieldName+"'] option").each(function(){
                for(var i=0;i<items.length;i++){
                    if(items[i][fieldName]==$(this).val()){
                        $(this).remove();
                    }
                }
            });             
        },
        error: function (error) {
            console.log(JSON.stringify(error));
        }
    });
    return fieldHTML;
}
</script>

在此处输入图像描述


推荐阅读