Я создаю новый список и пытаюсь добавить в него поле LookUp.
Я получаю список, по которому хочу посмотреть:
let list = sp.web.lists.getByTitle("Trucks");
list.get().then(list => {
this._ensureMyList("MySPListTest", list)
});
Затем я создаю новый список и новое поле:
private _ensureMyList(listName: string, truckList): void {
sp.web.lists.ensure(listName)
.then((ler: ListEnsureResult) => {
if (ler.created) {
console.info("list was created");
ler.list.fields.add("LookupTest", "SP.FieldLookup", {
Group: "~Example",
FieldTypeKind: 7,
Filterable: true,
Hidden: false,
EnforceUniqueValues: true,
})
.then((result) => {
console.info("result: ", result);
});
}
});
}
Я получаю сообщение об ошибке:
Uncaught (in promise) Error: Error making HttpClient request in queryable: [500] ::> {"responseBody":{"odata.error":{"code":"-2146232832, Microsoft.SharePoint.SPException","message":{"lang":"en-US","value":"Please use addfield to add a lookup field instead."}}},"responseHeaders":{}}
Я получил имя поля и TypeKind из:
https://msdn.microsoft.com/en-us/library/office/dn600182.aspx#bk_FieldLookup
Я также пробовал использовать метод addLookup
:
ler.list.fields.addLookup("LookupTest", truckList.Id, "Truck")
.then((result) => {
console.info("result: ", result);
});
С ошибкой:
Uncaught (in promise) Error: Error making HttpClient request in queryable: [400] ::> {"responseBody":{"odata.error":{"code":"-1, Microsoft.SharePoint.Client.InvalidClientQueryException","message":{"lang":"en-US","value":"The parameter __metadata does not exist in method AddField."}}},"responseHeaders":{}}
Вы можете рассмотреть следующие варианты добавления поля поиска:
1) через Fields.addLookup
метод:
let list = await sp.web.lists.getByTitle(listTitle); //get list resource
let lookupList = await sp.web.lists.getByTitle(lookupListTitle).select("Id").get(); //select Lookup List Id
let field = await list.fields.addLookup(lookupFieldName, lookupList.Id ,"Title"); // add lookup field to list
2) методом Fields.createFieldAsXml
:
let list = await sp.web.lists.getByTitle(listTitle); //get target list resource
let lookupList = await sp.web.lists.getByTitle("Categories").select("Id").get(); //determine lookup list id
let fieldXml = `<Field Name = "Category" Type = "Lookup" DisplayName = "Category" List = "{${lookupList.Id}}" ShowField = "Title"/>`; //construct lookup field schema
let field = await list.fields.createFieldAsXml(fieldXml); //add field to list
использованная литература
Обновлять
Относительно ошибки, возникающей при вызове метода Fields.addLookup
:
the parameter __metadata does not exist in method AddField.
похоже, что в последней версии (v1.2.1
) для Fields.addLookup
метод есть ошибка. Дело в том, что он генерирует полезную нагрузку неверный, примерно так:
{
"__metadata":{
"type":"SP.FieldCreationInformation"
},
"parameters": {
"FieldTypeKind":7,
"LookupFieldName":"Title",
"LookupListId":"{list-id}",
"Title":"Cat"
}
}
parameters
должен быть тегом корень в полезной нагрузке для конечной точки http://<site url>/_api/web/lists(guid'<list id>')/fields('<field id>')/addfield
(источник)
По истории эта ошибка была введена с одним из более поздних коммитов, в любом случае лучше сообщить о проблеме.
@ Holden1515, действительно так, ответ обновлен
Ах! Спасибо за копание и отправку отчета!
Вариант 1 дает мне те же ошибки в моем сообщении. Вариант 2 великолепен и работает, спасибо! Есть идеи, почему я продолжаю получать эти ошибки?