zoukankan      html  css  js  c++  java
  • 如何通过代码向 User 类型的字段里面添加 多个用户

    需求:要通过一个User字段,记录修改列表的人员信息,通过事件处理器

    程序实现:

    在添加事件里面添加代码:记录创建人的信息

             /// <summary>
            /// 已添加项.
            /// </summary>
            public override void ItemAdded(SPItemEventProperties properties)
            {
                SPListItem item = properties.ListItem;
                SPFieldUserValueCollection fuvc = new SPFieldUserValueCollection();
                SPUser user = properties.Web.EnsureUser(properties.UserLoginName);
                fuvc.Add(new SPFieldUserValue(properties.Web, user.ID, user.Name));
                item["UserType"] = fuvc;
                item.Update();
            }

    在修改事件里添加代码:记录修改人的信息,这里要添加一个判断,如果字段里面已经存在该用户,则不用再次添加用户信息

             /// <summary>
            /// 已更新项
            /// </summary>
            public override void ItemUpdated(SPItemEventProperties properties)
            {
                bool isTure = true;
                SPListItem listItem = properties.ListItem;
                SPUser user = properties.Web.EnsureUser(properties.UserLoginName);
                SPFieldUserValueCollection fieldUserValueCollection = listItem["UserType"] as SPFieldUserValueCollection;
                foreach (SPFieldUserValue userValue in fieldUserValueCollection)
                {
                    if (userValue != null)
                    {
                        if (userValue.LookupId == user.ID) //判断用户是否存在
                        {
                            isTure = false;
                            break;
                        }
                    }
                }

                if (isTure)
                {
                    fieldUserValueCollection.Add(new SPFieldUserValue(properties.Web, user.ID, user.LoginName));
                    listItem["UserType"] = fieldUserValueCollection;
                    listItem.Update();
                }
            }

    备注:第一次写程序的时候,把代码放到Adding事件里面总是出错,在小林的帮助下解决了问题

  • 相关阅读:
    一个贼基础的 编码解码方式
    SQL 中循环、for循环、游标
    sql中判断是否存在 数据库、表、存储过程、函数
    sql 同步表或同步表的时候更改部分字段
    sql存储过程的建立
    POJ
    UCloud 的安全秘钥 (计蒜客初赛第五场)(待解决)
    UCloud 机房的网络搭建(计蒜客初赛第五场)
    2017 计蒜之道 初赛 第四场
    腾讯课堂的物理实验(2017计蒜客初赛第三场)
  • 原文地址:https://www.cnblogs.com/Fengger/p/2535223.html
Copyright © 2011-2022 走看看