我正在创建一个用户集合,该集合能够在其中获取单个用户。这将用于从另一个系统进行匹配,所以我希望加载用户一次,然后能够在以后进行微调/匹配。但是,我在从内部方法访问外部用户集合时遇到问题。
function Users(){
var allUsers;
this.getUsers = function () {
// ajax to that Jasmine behaves
$.ajax({
url: '../app/data/jira_users.json',
async: false,
dataType: 'json',
success: function(data) {
allUsers = data;
}
});
return allUsers;
};
this.SingleUser = function (name) {
var rate = 0.0;
var position;
this.getRate = function () {
if(position === undefined){
console.log('>>info: getting user position to then find rate');
this.getPosition();
}
$.ajax({
url: '../app/data/rates.json',
async: false,
dataType: 'json',
success: function(data) {
rate = data[position];
}
});
return rate;
};
this.getPosition = function () {
console.log(allUsers);
//position = allUsers[name];
return position;
};
//set name prop for use later I guess.
this.name = name;
};
}
以及开始这一切的测试:
it("get single user's position", function(){
var users = new Users();
var someone = new users.SingleUser('bgrimes');
var position = someone.getPosition();
expect(position).not.toBeUndefined();
expect(position).toEqual('mgr');
});
getPosition 方法是问题(这可能很明显),因为 allUsers 始终未定义。我在这里是另一种尝试,我尝试了几种方法。我认为问题是如何开始调用 Users.getUsers,但我也不确定我使用的外部和内部变量是否正确。