是否可以动态创建 getJSON url 字符串?
Can a getJSON url string be dynamically created?
是否可以将此方法替换为 url 字符串:
$.when($.getJSON(url0), $.getJSON(url1), $.getJSON(url2), $.getJSON(url3)).then(function() { ...
使用另一个 JSON 文件?
为什么? url 项的数量发生了变化,我想从一个文件中提取它们,而不必每次都修改此代码所在的位置。我可能正在处理 url0-url3 或 url0-40 然后回到 url0-url20.
当前方法强制手动更新用于构建 url 字符串的数组以及更新函数。
你有什么建议?
也许是这样的?
var urls = [
'http://jsonplaceholder.typicode.com/posts/18',
'http://jsonplaceholder.typicode.com/posts/37'
];
var results = {};
function saveResult(urlPath, data) {
results[urlPath] = data;
}
function f() {
($.when).apply(this, Array.prototype.slice.call(arguments).map(function(urlPath) {
return $.getJSON(urlPath, saveResult.bind(this, urlPath));
})).then(function() {
console.log('Completed fetch', results);
});
}
f.apply(this, urls);
更新:如果你想从文件中获取 url,像这样的东西应该可以工作:
function makeUrls(cb) {
var urls = [];
var idString1 = '???', idString2 = '????';
$.when($.getJSON('new_name2.json')).then(function(c) {
$.each(c.myStuff, function(f, e) {
urls.push(idString1 + e.id + idString2);
});
cb(urls);
});
}
var results = {};
function saveResult(urlPath, data) {
results[urlPath] = data;
}
function f() {
($.when).apply(this, Array.prototype.slice.call(arguments).map(function(urlPath) {
return $.getJSON(urlPath, saveResult.bind(this, urlPath));
})).then(function() { console.log('DID IT!', results); });
}
makeUrls(function(urls) {
f.apply(this, urls);
});
是否可以将此方法替换为 url 字符串:
$.when($.getJSON(url0), $.getJSON(url1), $.getJSON(url2), $.getJSON(url3)).then(function() { ...
使用另一个 JSON 文件?
为什么? url 项的数量发生了变化,我想从一个文件中提取它们,而不必每次都修改此代码所在的位置。我可能正在处理 url0-url3 或 url0-40 然后回到 url0-url20.
当前方法强制手动更新用于构建 url 字符串的数组以及更新函数。
你有什么建议?
也许是这样的?
var urls = [
'http://jsonplaceholder.typicode.com/posts/18',
'http://jsonplaceholder.typicode.com/posts/37'
];
var results = {};
function saveResult(urlPath, data) {
results[urlPath] = data;
}
function f() {
($.when).apply(this, Array.prototype.slice.call(arguments).map(function(urlPath) {
return $.getJSON(urlPath, saveResult.bind(this, urlPath));
})).then(function() {
console.log('Completed fetch', results);
});
}
f.apply(this, urls);
更新:如果你想从文件中获取 url,像这样的东西应该可以工作:
function makeUrls(cb) {
var urls = [];
var idString1 = '???', idString2 = '????';
$.when($.getJSON('new_name2.json')).then(function(c) {
$.each(c.myStuff, function(f, e) {
urls.push(idString1 + e.id + idString2);
});
cb(urls);
});
}
var results = {};
function saveResult(urlPath, data) {
results[urlPath] = data;
}
function f() {
($.when).apply(this, Array.prototype.slice.call(arguments).map(function(urlPath) {
return $.getJSON(urlPath, saveResult.bind(this, urlPath));
})).then(function() { console.log('DID IT!', results); });
}
makeUrls(function(urls) {
f.apply(this, urls);
});