我正在使用SharePoint 2013开发和JavaScript进行双重学习。
请参阅下文。
function GetListFields(listname, viewname, ResultCallBackFunction)
{
var clientContext = new SP.ClientContext.get_current();
var web = clientContext.get_web();
var list = web.get_lists().getByTitle(listname);
if (viewname == "")
{
var view = list.get_views().getByTitle(viewname);
var listFields = view.get_viewFields();
}
else
{
this.listFields = list.get_fields().getByInternalNameOrTitle("Title");
}
clientContext.load(this.listFields);
clientContext.executeQueryAsync(onListFieldsQuerySucceeded, onListFieldsQueryFailed);
function onListFieldsQuerySucceeded()
{
console.log(listFields.get_fields().getByInternalNameOrTitle("Title").get_internalName());
var fldArray = new Array();
var fieldEnumerator = listFields.getEnumerator();
while (fieldEnumerator.moveNext())
{
var oField = fieldEnumerator.get_current();
fldArray.push(oField);
}
ResultCallBackFunction(fldArray);
}
function onListFieldsQueryFailed()
{
alert("Something went wrong. The End is Nigh.");
}
}
目的是调用 GetListFields 返回一个包含列表字段名的数组。这将在“console.log ....”行返回错误“无法获取未定义或空引用的属性'get_fields'”。请注意,这是我的调试。
如果我更改函数 GetListFields 的代码,如下所示:
var clientContext = new SP.ClientContext.get_current();
var web = clientContext.get_web();
var list = web.get_lists().getByTitle(listname);
if (viewname == "")
viewname = "All Items";
var view = list.get_views().getByTitle(viewname);
this.listFields = view.get_viewFields();
我得到一个结果,但是这里包含一个名为'LinkTitle'的字段,我在列表中没有这个字段,因为我重命名了这个字段。我错过了什么?
除此之外,我在使用
时出错var listFields = ...
通过执行
来解决this.listFields = ...
但不明白其中的区别。
感谢您提供任何帮助或指示。
答案 0 :(得分:1)
我花了一些时间在我的Sharepoint 2013环境中测试您的代码。
我做了一些改动,现在它有效。
您可以在下面看到生成的脚本。
以下是结果数组中字段名称的一些重要信息。
Sharepoint返回的视图中的字段名称是内部名称,而不是字段的标题。
这就是为什么你得到LinkTitle而不是你的领域的真实标题的原因。
在Sharepoint界面中创建字段时,Sharepoint会为字段创建标题,并根据标题创建内部名称。
例如,如果我创建一个名为«my test field»的字段,Sharepoint会说该字段的标题是«my test field»,内部名称是«my_x0020_test_x0020_field»。
<script>
function GetListFields(listname, viewname, ResultCallBackFunction)
{
var clientContext = new SP.ClientContext.get_current();
var web = clientContext.get_web();
var list = web.get_lists().getByTitle(listname);
var listFields;
var view;
var defaultViewName = 'All Items';
if (viewname === "")
{
viewname = defaultViewName;
}
view = list.get_views().getByTitle(viewname);
listFields = view.get_viewFields();
clientContext.load(listFields);
clientContext.executeQueryAsync(onListFieldsQuerySucceeded, onListFieldsQueryFailed);
function onListFieldsQuerySucceeded()
{
var fldArray = new Array();
var fieldEnumerator = listFields.getEnumerator();
while (fieldEnumerator.moveNext())
{
var oField = fieldEnumerator.get_current();
fldArray.push(oField);
}
ResultCallBackFunction(fldArray);
}
function onListFieldsQueryFailed()
{
alert("Something went wrong. The End is Nigh.");
}
}
function MyCallBack(fieldArray) {
for (var x=0;x<fieldArray.length;x++) {
console.log(fieldArray[x]);
}
}
</script>
<a id="callGetListFields" href="#" onclick="GetListFields('MyListName','MyViewName', MyCallBack);">Call function GetListFields</a>
希望这有帮助!