zoukankan      html  css  js  c++  java
  • 从PeopleEditor控件中取出多用户并更新到列表

    如果一个列表中有一个字段类型为用户或用户组,并且设置为用户,允许多值的话,那么用代码进行更新的时候就必须将这个字段的值赋成SPFieldUserValueCollection类型,以下代码即为从PeopleEditor控件中取出多个用户并返回一个SPFieldUserValueCollection类型的值:

     1 /// <summary>
     2         /// 从人员选取器中获取多用户并返回SPFieldUserValueCollection类型
     3         /// </summary>
     4         /// <param name="pe">人员选取器</param>
     5         /// <returns></returns> ToString:user1ID;#user1Name;#user2ID;#user2Name
     6         public SPFieldUserValueCollection GetUsersValue(PeopleEditor pe)
     7         {
     8             SPFieldUserValueCollection result = new SPFieldUserValueCollection();
     9             using (SPSite mySite = new SPSite(SPContext.Current.Site.ID))
    10             {
    11                 using (SPWeb myWeb = mySite.RootWeb)
    12                 {
    13                     if (pe.CommaSeparatedAccounts != "")
    14                     {
    15                         foreach (string item in pe.CommaSeparatedAccounts.Split(','))
    16                         {
    17                             SPUser u = myWeb.EnsureUser(item);
    18                             SPFieldUserValue uservalue = new SPFieldUserValue(myWeb, u.ID, u.Name);
    19                             result.Add(uservalue);
    20                         }
    21                     }
    22                 }
    23             }
    24             return result;
    25         }

    更新的时候直接将item["user"]=GetUsersValue(pe);然后Update一下即可。

    另外如果需要通过代码将多用户赋值给PeopleEditor控件,只需要设置PeopleEditor控件的CommaSeparatedAccounts属性为User1Name,User2Name这样即可,即为每个用户的DisplayName,然后之间用“,”隔开就可以了,代码如下:

    pe.CommaSeparatedAccounts="User1Name,User2Name";
    
  • 相关阅读:
    json
    封装PDO
    PDO
    jquery练习
    jquery包
    jquery
    租房子 多条件查询
    查询
    新闻修改处理页面
    新闻添加数据
  • 原文地址:https://www.cnblogs.com/tdskee/p/3421105.html
Copyright © 2011-2022 走看看