我尝试使用javascript搜索名为“John”的人的Sharepoint列表。看起来好像查询失败了,因为我得到一个错误警告:请求失败。未正确安装一个或多个字段类型。转到列表设置页面以删除这些字段。未定义
这表明脚本最终出现在onQueryFailed()方法中。我发现CAML没有任何问题,并且使用了内部列名。
来自.aspx的代码:
<script type="text/javascript">
function MyJavascript() {
var siteUrl = '/sites/MySite/';
var clientContext = new SP.ClientContext(siteUrl);
var oList = clientContext.get_web().get_lists().getByTitle('People');
var camlQuery = new SP.CamlQuery();
camlQuery.set_viewXml('<View><Query><Where><Eq><FieldRef Name="\'Name\'"/>' +
'<Value Type=\'Text\'>John</Value></Eq></Where></Query></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() +
'\nName: ' + oListItem.get_item('Name') +
'\nAge: ' + oListItem.get_item('Age');
}
alert(listItemInfo.toString());
}
function onQueryFailed(sender, args) {
alert('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}
</script>
将脚本注册到按钮的.cs代码:
SubmitButton.Attributes.Add("onclick", "MyJavascript(); return false;");
有什么想法吗?
答案 0 :(得分:0)
尝试将ExecuteOrDelayUntilScriptLoaded(MyJavaScript, "sp.js");
直接放在siteUrl
变量下方。