SP.js "Uncaught TypeError: Object [object Object] не имеет метода 'get_staticObjects'"
Я пытаюсь написать небольшой SPA, который действует как слой пользовательского интерфейса для списка SharePoint.
Я успешно сделал это с помощью обычного вызова AJAX, но из-за ограничений этого метода теперь я хочу сделать это с помощью объектной модели JavaScript.
Проблема, с которой я сталкиваюсь, - это ошибка в SP.js (из заголовка):
* Uncaught TypeError: Object [object Object] не имеет метода 'get_staticObjects'*
Это в значительной степени мешает мне даже добраться до сценария.
Вот код для страницы:
<!DOCTYPE html>
<html>
<head>
<title>JavaScript Object Model Test</title>
<script type="text/javascript" src="js/jquery-1.10.2.min.js"></script>
<script type="text/javascript" src="js/knockout-2.3.0.js"></script>
<script type="text/javascript" src="/_layouts/MicrosoftAjax.js"></script>
<script type="text/javascript" src="/_layouts/1033/init.js"></script>
<script type="text/javascript" src="/_layouts/SP.js"></script>
<script type="text/javascript" src="/_layouts/SP.Core.js"></script>
</head>
<body>
<script type="text/javascript">
var siteUrl = '/sites/MySiteCollection';
function retrieveListItems() {
var clientContext = new SP.ClientContext(siteUrl);
var oList = clientContext.get_web().get_lists().getByTitle('Announcements');
var camlQuery = new SP.CamlQuery();
camlQuery.set_viewXml('<View><Query><Where><Geq><FieldRef Name=\'ID\'/>' +
'<Value Type=\'Number\'>1</Value></Geq></Where></Query><RowLimit>10</RowLimit></View>');
this.collListItem = oList.getItems(camlQuery);
clientContext.load(collListItem);
clientContext.executeQueryAsync(Function.createDelegate(this, this.onQuerySucceeded), Function.createDelegate(this, this.onQueryFailed));
}
function onQuerySucceeded(sender, args) {
var listItemInfo = '';
var listItemEnumerator = collListItem.getEnumerator();
while (listItemEnumerator.moveNext()) {
var oListItem = listItemEnumerator.get_current();
listItemInfo += '\nID: ' + oListItem.get_id() +
'\nTitle: ' + oListItem.get_item('Title') +
'\nBody: ' + oListItem.get_item('Body');
}
alert(listItemInfo.toString());
}
function onQueryFailed(sender, args) {
alert('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}
ExecuteOrDelayUntilScriptLoaded(retrieveListItems, "sp.js");
</script>
</body>
</html>
Когда я запускаю это, ничего не происходит, но консоль выдает ошибку выше.
1 ответ
Мне удалось решить эту проблему, создав пустую страницу в SharePoint Designer и внедрив в нее свой HTML-код и ссылки на мои скрипты. SharePoint не будет правильно загружать инфраструктуру JavaScript на странице HTML - только на странице ASPX, созданной SharePoint.