8

指定されたURLからJSONデータを返そうとしていますが、アラートがポップアップすると、[object Object]と表示されます(オブジェクトオブジェクトは実際にはエラーではないことがわかります)。アラートのポジション名などを吐き出したいのですが。どうすればよいですか?

これが私が見ているJSONの例です(完全なファイルには約30の投稿があります)

[
  {
    "m_id": 473644,
    "m_positionName": "Application Monitoring Software Engineer",
    "m_positionLocations": [
      {}
    ],
    "m_active": true,
    "m_description": "Job Responsibilities:\r\n\r\n-Create world class application monitoring tools and dashboards for our health care applications\r\n\r\n-Develop business rules to pro actively identify and re-mediate system-level issues before they occur.\r\n\r\n-Create business intelligence reports for internal and external use as a supplement to software products.\r\n\r\n\r\n\r\nJob Requirements:\r\n\r\n-BS or MS Degree in computer science or any engineering discipline.\r\n-4+ years of experience with Java (or other object-oriented programming language).\r\n-Experience in SQL, Struts, Hibernate, Spring, Eclipse, JSP, JavaScript.\r\n-Highly motivated and self-driven personality.\r\n-Excellent interpersonal and leadership skills.\r\n-A vision for the future and a desire to make a difference.\r\n-Experience with Maven, Tomcat, PostgreSql, Jasper Reports,",
    "m_postedDate": "Jun 29, 2012 9:17:19 AM",
    "m_closingDate": "Jun 29, 2013 12:00:00 AM"
  }
]

そして、これが私が使用しているスクリプトです。

 $.ajax({
 type: "GET",
 url: '/wp-content/themes/twentyeleven/js/jobopenings.json',
 async: false,
 beforeSend: function(x) {
  if(x && x.overrideMimeType) {
   x.overrideMimeType("application/j-son;charset=UTF-8");
  }
 },
dataType: "json",
success: function(data){
alert(data);
}
});

どんな助けでも大歓迎です。

4

3 に答える 3

19

いつでもオブジェクトを文字列に変換して警告することができます。

alert(JSON.stringify(data));
于 2012-11-19T15:15:16.723 に答える
7

これを試して:

success: function(data)
{
  var _len = data.length;
  , post, i;

  for (i = 0; i < _len; i++) {
    //debugger
    post = data[i];
    alert("m_positionName is "+ post. m_positionName);
  }
}
于 2012-11-19T15:24:33.273 に答える
1

jQueryがjsonを受信すると、jQueryはそれを自動的にjavascriptオブジェクトに変換します。つまりdata、すぐに使用できるオブジェクトが含まれているだけです。応答の元のテキストにアクセスしたい場合は、次のようにすることができます。

success: function(data, textStatus, jqXHR){
    alert(jqXHR.responseText);
}
于 2012-11-19T15:19:02.427 に答える