我有一个脚本,是90%的完整和工作。我使用较旧的代码来获取LRS语句。它是使用tincan.js的。我正在尝试删除并解析以下内容:参与者、动词、对象、时间戳和contextActivities下的id 。这是最后一次让我适应。请你看一下我最后一次试试看,告诉我哪里出了问题?谢谢。
<!DOCTYPE html>
<!--Parsing "resumed" statements-->
<html lang='en'>
<head>
<meta charset='UTF-8'>
<title>Get my Statements</title>
<script type="text/javascript" src="build/tincan.js"></script>
</head>
<body>
<h1>Get statements 101</h1>
<div id='response'></div>
<script>
var lrs;
try {
lrs = new TinCan.LRS(
{
endpoint: "https://lrs.adlnet.gov/xapi/",
username: "xapi-tools",
password: "xapi-tools",
allowFail: false
}
);
}
catch (ex) {
console.log("Failed to setup LRS object: " + ex);
// TODO: do something with error, can't communicate with LRS
}
//Pulls all of the resumed statements
lrs.queryStatements(
{
params: {
verb: new TinCan.Verb(
{
id: "http://adlnet.gov/expapi/verbs/completed"
}
),
since: "2016-01-05T08:34:16Z"
},
callback: function (err, sr) {
if (err !== null) {
console.log("Failed to query statements: " + err);
// TODO: do something with error, didn't get statements
return;
}
if (sr.more !== null) {
// TODO: additional page(s) of statements should be fetched
}
var container = document.getElementById('response');
//container.innerHTML = (err !== null ? 'ERROR' : JSON.stringify(sr.statements));
container.innerHTML = (err !== null ? 'ERROR' : parseMyData(sr));
}
}
);
parseMyData = function(result) {
var statements = result.statements;
var output = '';
var name,verb,activity, timestamp, context;
for(var i=0;i<statements.length;i++){
// check the statement for a usable name value
// (priority = actor.name, actor.mbox, actor.account.name)
if(statements[i].actor.name != null && statements[i].actor.name != "") {
name = statements[i].actor.name
}else if(statements[i].actor.mbox != null && statements[i].actor.mbox != "") {
name = statements[i].actor.mbox
}else{
name = statements[i].actor.account.name
}
// check the statement for a usable verb value
// (priority = verb.display['en-US'], verb.id)
try{
verb = statements[i].verb.display['en-US'];
}catch(e){
verb = statements[i].verb.id;
}
// check the activity for a usable value
// (priority = definition.name['en-US'], id)
try{
activity = statements[i].target.definition.name['en-US'];
}catch(e){
activity = statements[i].target.id;
}
try{
timestamp = statements[i].timestamp;
}catch(e){
timestamp = statements[i].timestamp;
}
try{
context = statements[i].target.contextActivities.other['id'];
}catch(e){
context = statements[i].activity.other['id'];
}
output += name + ' - ' +
verb + ' - ' +
activity + ' - ' +
timestamp + ' - ' +
context +
'<br>'
}
return output;
}
</script>
</body>
</html>发布于 2017-03-28 18:08:03
您正在尝试访问一个永远不存在的属性:
statements[i].target.contextActivities
当它存在时,它的最后一部分将在statements[i].context中存在,除非您提前知道该语句,否则它并不总是存在的。在访问属性之前,几乎所有的属性都应该检查null,这样做将允许您删除try/catch块。属性名称本身非常稳定,库显式地将null值分配给已知的属性。此外,other属性将包含一个活动数组(当它被填充时),因此您应该通过索引、contextActivities.other[0].id等来访问它们。
对于target属性,您应该检查它是否是特定类的实例,因为它可以包含多种类型的对象( actor也可以,但它们实际上是匹配的)。通常,对于这个特定的任务,您可能还希望在可能的情况下利用toString方法,它们做的工作非常相似。
https://stackoverflow.com/questions/42913444
复制相似问题