4

当我尝试从以下位置获取 id 时:

string idValue = item[Lookup].ToString();

我通过示例得到下一个值:

1;#1

我需要这样的价值:

1

实际上这段代码处理了要求:

using (SPSite site = new SPSite(context.CurrentWebUrl))
{
    using (SPWeb web = site.OpenWeb())
    {
        //Context list                 
        SPList list = web.Lists[context.ListId];
        SPList child = web.Lists[List]; 
        SPListItem currentItem = list.GetItemById(context.ItemId);
        string updateItems = "";
        int ID = currentItem.ID;

        foreach (SPListItem item in child.Items)
        {
            string idValue = item[Lookup].ToString();
            int partial = idValue.LastIndexOf(";");
            string idPure = idValue.Substring(0, partial);

            if (idPure == ID.ToString())
            {
                item[Field] = Value;
                item.Update();
                updateItems += item.ID.ToString();
            }
        }              

        //Return Items*/
        results["Items"] = updateItems;
        SPWorkflow.CreateHistoryEvent(web, context.WorkflowInstanceId, 0,
            web.CurrentUser, TimeSpan.Zero, "Information",
            "Event from sandboxed, updates: " + updateItems, string.Empty);
    }
}

我想知道一个更好的函数或属性来从查找字段中获取 ID。

4

3 回答 3

20
SPFieldLookupValue fieldLookupValue = new SPFieldLookupValue(item["FieldName"].ToString());
int lookupID = fieldLookupValue.LookupId;

干得好 :)

于 2013-10-14T16:33:23.073 回答
0
    SPList mySPList = oWeb.Lists["ProjectList"];
newItem["LookupFieldName"] = new SPFieldLookupValue(getLookUp(mySPList,LookupFieldValue), LookupFieldValue);



public static int getLookUp(SPList oList, string FieldValue, string sFieldName="Title")
        {

            foreach (SPListItem spi in oList.GetItems())
            {
                if (spi[sFieldName].ToString() == FieldValue)
                {
                    return spi.ID;
                }
            }
            return 0;
        }
于 2017-08-26T06:09:50.193 回答
0

我可以使用此代码在 SharePoint 中设置查找字段

<script>

window.onload = (event) => {
document.getElementById("tafahomNameId_78ec7c44-beab-40de-9326-095f474519f4_$LookupField").value = 1;
};

</script>
于 2021-03-30T10:45:25.257 回答