Javascript 不渲染视图
我试图在通过rdflib.js检索联系人列表后呈现它。它正在正确加载并保存在范围内的列表中 它确实可以识别列表中的项目数,但由于$scope没有更新,我无法呈现值,似乎我在错误的位置调用了$scope.apply()。这似乎是因为我将其称为外部angular,但我故意将其称为外部angular上下文(现在或何时蚀刻)的函数内部,因此对我来说没有意义。有什么帮助吗Javascript 不渲染视图,javascript,angularjs,Javascript,Angularjs,我试图在通过rdflib.js检索联系人列表后呈现它。它正在正确加载并保存在范围内的列表中 它确实可以识别列表中的项目数,但由于$scope没有更新,我无法呈现值,似乎我在错误的位置调用了$scope.apply()。这似乎是因为我将其称为外部angular,但我故意将其称为外部angular上下文(现在或何时蚀刻)的函数内部,因此对我来说没有意义。有什么帮助吗 $scope.load = function () { //$scope.getContactsList(); var
$scope.load = function () {
//$scope.getContactsList();
var g = $rdf.graph();
var f = $rdf.fetcher(g);
f.nowOrWhenFetched($scope.path + '*',undefined,function(){
var DC = $rdf.Namespace('http://purl.org/dc/elements/1.1/');
var RDF = $rdf.Namespace('http://www.w3.org/1999/02/22-rdf-syntax-ns#');
var LDP = $rdf.Namespace('http://www.w3.org/ns/ldp#');
//var myOntology = $rdf.Namespace('http://user.pds.org/ontology/');
var VCARD = $rdf.Namespace('http://www.w3.org/2006/vcard/ns#');
var evs = g.statementsMatching(undefined, RDF('type'), VCARD('Individual'));
if (evs != undefined) {
for (var e in evs) {
var id = evs[e]['subject']['value'];
var fullname = g.anyStatementMatching(evs[e]['subject'], VCARD('fn'))['object']['value'];
var email = g.anyStatementMatching(evs[e]['subject'], VCARD('hasEmail'))['object']['value'];
var phone = g.anyStatementMatching(evs[e]['subject'], VCARD('hasTelephone'))['object']['value'];
var contact = {
id: id.slice(id.length-1),
Name: fullname,
Email: email,
Phone: phone
};
$scope.contacts.push(contact);
}
}
$scope.apply();
});
};
谢谢。您是否已将$scope.contacts定义为数组?只想确定你没有打电话。按undefined?是,$scope.contacts=[];在定义此$scope.load()的控制器内定义。请尝试$scope.$apply(函数(){…});图案$scope.apply函数是什么?@lujcon的第一种方法是呈现与列表长度相同的行数。您建议的这种方式不呈现任何内容在angular中没有类似$scope.apply()的东西。函数名为$apply,在代码末尾调用它时,您应该使用此函数包装代码。这样,angular将调用$digest,如果出现错误,则将它们扔到控制台。