I am trying to write a small SPA that acts as a UI layer for a SharePoint list.
I have successfully done so with a regular AJAX call, but, due to the limitations of that method, I now want to do so with the JavaScript Object Model.
The problem I am encountering is an error with SP.js (from the title):
*Uncaught TypeError: Object [object Object] has no method 'get_staticObjects'*
This pretty much prevents me from even getting to the script.
Here is the code for the page:
<!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>
When I run that, nothing happens, but the console outputs the error above.
I managed to solve this issue by creating a blank page in SharePoint Designer and embedding my HTML and linking to my scripts in that. SharePoint will not properly load the JavaScript framework in an HTML page--only in an SharePoint-created ASPX page.