関数でオブジェクトを返していますがundefined
、なぜ返されますか? ここに私のコードがあります
parseXML = function (xml) {
return {
lon : $(xml).find('GEOCODE').find("LOC").attr('lon'),
lat : $(xml).find('GEOCODE').find("LOC").attr('lat'),
x : $(xml).find('GEOCODE').find("LOC").attr('x'),
y : $(xml).find('GEOCODE').find("LOC").attr('y')
};
},
searchRoute = function () {
var userloc, dest;
userloc = cityattr.init(from, to, fromurl, parseXML);
//dest = cityattr.init(from, to, fromurl, parseXML);
console.log(userloc);
};
アップデート
console.log()
parseXML 内で行うと、正しいオブジェクトが返されます
parseXML = function (xml) {
var obj = {
lon : $(xml).find('GEOCODE').find("LOC").attr('lon'),
lat : $(xml).find('GEOCODE').find("LOC").attr('lat'),
x : $(xml).find('GEOCODE').find("LOC").attr('x'),
y : $(xml).find('GEOCODE').find("LOC").attr('y')
};
console.log(obj);
},
更新 2
まだ戻るundefined
parseXML = function (xml) {
return {
lon : $(xml).find('GEOCODE').find("LOC").attr('lon'),
lat : $(xml).find('GEOCODE').find("LOC").attr('lat'),
x : $(xml).find('GEOCODE').find("LOC").attr('x'),
y : $(xml).find('GEOCODE').find("LOC").attr('y')
};
},
ここにcityattrのコードがあります
var Xml = function () {
var to, from, url, result,
init = function (fromaddress, toaddress, link, callback) {
from = fromaddress;
to = toaddress;
url = link;
requestXml(callback);
},
requestXml = function (callback) {
$.ajax({
type: "GET",
url: url,
dataType: "xml",
success: callback
});
},
getResult = function () {
return result;
};
return {
init : init,
getResult : getResult
};
};