自定义 SharePoint Web 部件 - 自定义属性设置问题



我正在开发一个自定义列表搜索工具。我有多个自定义属性要保留,这些属性列出了搜索查询,以及要在搜索中查询的字段。

示例用户界面

下拉列表(列表中的选定字段) 文本框(查询) "搜索"按钮

我的问题是,在加载 WebPart 时,"要搜索的字段"属性是在"要搜索的列表"属性之前设置的,这会导致和错误,因为我有一个检查以确保字段确实存在于正确的列表中,然后再将它们添加到下拉列表中。

有没有办法指定 Web 部件属性在加载时设置的顺序?

我认为在这种情况下

,最简单的方法是将验证逻辑从属性库移到另一个方法(例如CreateChildControls)。通过这样做,您将删除对属性设置顺序的任何依赖。

我的 Web 部件属性中通常没有逻辑(或非常非常少)。我从一开始就在CreateChildControls内/从进行所有验证。然后,如果某些属性的值缺失或无效,我可以引发异常,或者更典型的是使用 Web 部件的输出写出描述性消息。

    [Category("Search Settings"),
Personalizable(PersonalizationScope.Shared),
WebBrowsable(true), WebDisplayName("List Name"),
WebDescription("Enter list name")]
    public string CustomTextProp {
        get { return listToSearch; }
        set {
            int existsFlag = 0;
            foreach (SPList spl in thisWeb.Lists) {
                if (spl.Title == value || value == string.Empty) {
                    existsFlag = 1;
                    break;
                }
            }
            if (existsFlag == 1) {
                listToSearch = value;
            } else {
                throw new WebPartPages.WebPartPageUserException("The list entered does not exist - Enter an existing list or create a new one");
            }
        }
    }
[Category("Search Settings"),
Personalizable(PersonalizationScope.Shared),
WebBrowsable(true), WebDisplayName("Search Field Options (Separate by comma ',')"),
WebDescription("Enter Fields to Search By")]
    public string SearchByOptions {
        get {
            return searchByOptions;
        }
        set {//between here
            //  int validFlag = 1;
            //  foreach (string str in SeparateByComma(value)) {
            //    if (!FieldExists(str, CustomTextProp)) {
            //      validFlag = 0;
            //      break;
            //    }
            //  }
            //  if (validFlag == 1) {
            searchByOptions = value;
            //  } else {
            //    throw new WebPartPages.WebPartPageUserException("Option is null or one or more fields do not exist/have been entered incorrectly");
            //  }//and here
        }
    }

最新更新