在一个函数中获取几个JSON文件

时间:2016-10-20 11:42:50

标签: javascript jquery angularjs json jsonp

JSON链接的结构如下:

  

www.something.com/link-的 -rest-的最link.com.json

现在我需要获取几个JSON链接文件,唯一改变的是上面链接中的数字部分。假设它的范围从10到40,所以第一个看起来像这样:

  

www.something.com/link-的 10 -rest-的最link.json

,第二个看起来像这个

  

www.something.com/link-的 11 -rest-的最link.com.json

依此类推,直至达到40号。

有没有办法可以在一个功能中完成所有功能。我试过这个:

var nmr = function({for(nmr=10;nmr<40;nmr++)});

var json = 'www.something.com/link'+nmr+'rest-of-the-link.json';

但它不起作用。

有没有办法实现这个目标?

请注意,由于SO自动链接,我没有放“http”部分。

感谢。

3 个答案:

答案 0 :(得分:1)

试试这个,

var json = [];
for(var i = 10; i <= 40; i++) {
   json.push('www.something.com/link-'+i+'-rest-of-the-link.json');
}

现在json将包含从10到40的所有链接。如果您想获取内容,请使用ajax来执行此操作

答案 1 :(得分:1)

你可以像这样构建数组

var links = [];
for(var i=2005;i<2015.length;i++){
  links.push('http://www.link.com/an-'+i+'-rest');
}
//now make your request for each link

另一个例子

var requested = 0;
  function startLoading(){
    if(requested==2015) {
      return alert("all files loaded");
    }
    makeRequest('http://www.link.com/an-'+requested+'-rest');
  }

  function makeRequest(url){
    //the body of request
    //then
    //if response is ready make what you want for it and go next
    requested++;
    startLoading();
    // and startLoading(); to go to the next link
  }

  startLoading(); //start

答案 2 :(得分:0)

<强>概念

  • 生成将从url调用每个json文件的promises数组

  • 同时执行每个承诺

<强>样品

const Promise = require('bluebird')
const rp = require('request-promise')

function getJsonFromUrlParam(num) {
  const uri = `www.something.com/link-${num}-rest-of-the-link.json`

  return rp({ method: 'GET', uri, json: true })
}

/** declare param */
const params = []

for (let i = 10; i <= 40; i++) {
  /** get each promise param */
  params.push(getJsonFromUrlParam(i))
}

/** get each json file in the same time */
Promise.all(params)
  .then(result => {
    /** get result here 
     * result is array of json files
     */
     console.log(result)
  })