option
のselect
要素に入れる学校のリストを取得しようとしています。ページが読み込まれたときにドロップダウンオプションを追加したいが、私は何か正しいことをしていない。以下のコードは、button
要素で直接呼び出すが、ページの読み込みでは機能しない場合に機能します。ライン上のSharepoint Javascriptでページの読み込みに失敗する
私が手にエラーが "オブジェクトはこのアクションをサポートしていない" であるvar clientContext = new SP.ClientContext(siteUrl);
var siteUrl= '/learning/schools';
window.load = init();
function init(){
SP.SOD.executeFunc('sp.js', 'SP.ClientContext', retrieveListItems());
}
function retrieveListItems() {
var clientContext = new SP.ClientContext(siteUrl);
var oList = clientContext.get_web().get_lists().getByTitle('Schools');
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();
var schoolCodes = document.getElementById('classSchoolList');
while (listItemEnumerator.moveNext()) {
var oListItem = listItemEnumerator.get_current();
var schoolOption = document.createElement('option');
schoolOption.value = oListItem.get_item('Title');
schoolOption.text = oListItem.get_item('Title') + " : " + oListItem.get_item('School');
schoolCodes.add(schoolOption);
}
}
function onQueryFailed(sender, args) {
alert('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}
コードが正しいようです。次の行のようにカッコで囲まずに関数名を 'retrieveListItems'として試してみてください。' SP.SOD.executeFunc( 'sp.js'、 'SP.ClientContext'、retrieveListItems); '。 これを参照してください:https://sharepoint.stackexchange.com/questions/79010/sharepoint-com-sp-clientcontextsiteurl-object-doesnt-support-this-action –
@rohit私はそれを試みましたが、それはまだ同じ時点で失敗します。ページの読み込み。しかし、私はクリックして、それは正常に動作するボタンがあります。 –