javascript - $.getJSON 请求在单击按钮时不起作用

标签 javascript jquery html json api

我试图找到解决这个问题的方法,但我目前不知所措。我正在尝试使用 twitch API 收集关于流的信息。

当我传入一组用户名时,我能够得到一个 .getJSON 请求来工作,如果用户离线或无效,则返回 null。

$(document).ready(function() {
  var streamers = ["ESL_SC2","OgamingSC2","cretetion","freecodecamp","storbeck","habathcx","RobotCaleb","noobs2ninjas","meteos","c9sneaky","JoshOG"];
  var url = "https://api.twitch.tv/kraken/streams/";
  var cb = "?client_id=5j0r5b7qb7kro03fvka3o8kbq262wwm&callback=?";

  getInitialStreams(streamers, url, cb); //load hard-coded streams
});

function getInitialStreams(streamers, url, cb) {
  //loop through the streamers array to add the initial streams
  for (var i = 0; i < streamers.length; i++) {
    (function(i) {
      $.getJSON(url + streamers[i] + cb, function(data) {
        //If data is returned, the streamer is online
        if (data.stream != null) {
          console.log("online");
        } else {
          console.log("offline");
        }
      });
    })(i);
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form class="form-inline">
      <input id="addStreamerForm" class="form-control" type="text" placeholder="Add a Streamer">
      <button id="addStreamerBtn" class="btn" type="submit">Add</button>
</form>

但是,当我尝试通过点击功能调用 API(最终通过表单提取任何输入)时,.getJSON 失败。如下所示。

$(document).ready(function() {
  var url = "https://api.twitch.tv/kraken/streams/";
  var cb = "?client_id=5j0r5b7qb7kro03fvka3o8kbq262wwm&callback=?";

  $("#addStreamerBtn").click(function(e) {
    addStreamer("Ben", url, cb);
  });
});

function addStreamer(streamer, url, cb) {
  console.log("I'm inside the function");
  $.getJSON(url + streamer + cb, function(data) {
    console.log("WE DID IT");
  });
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form class="form-inline">
  <input id="addStreamerForm" class="form-control" type="text" placeholder="Add a Streamer">
  <button id="addStreamerBtn" class="btn" type="submit">Add</button>
</form>

我不明白为什么代码不适用于第二个片段。任何指导将不胜感激。

最佳答案

问题是因为您已 Hook 到提交按钮的 click 事件。这意味着 form 是在您的 AJAX 请求发生时提交的,因此页面会立即卸载并取消 AJAX。

要解决此问题,请连接到 formsubmit 事件,并对该事件调用 preventDefault()。试试这个:

$(document).ready(function() {
  var url = "https://api.twitch.tv/kraken/streams/";
  var cb = "?client_id=5j0r5b7qb7kro03fvka3o8kbq262wwm&callback=?";

  $(".form-inline").submit(function(e) {
    e.preventDefault();
    addStreamer("Ben", url, cb);
  });
});

function addStreamer(streamer, url, cb) {
  console.log("I'm inside the function");
  $.getJSON(url + streamer + cb, function(data) {
    console.log("WE DID IT");
  });
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form class="form-inline">
  <input id="addStreamerForm" class="form-control" type="text" placeholder="Add a Streamer">
  <button id="addStreamerBtn" class="btn" type="submit">Add</button>
</form>

关于javascript - $.getJSON 请求在单击按钮时不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43974050/

相关文章:

javascript - jQuery toggleClass 显示不同菜单相关

jquery - 显示默认图标,如果在 div 上设置了类,则替换图标

javascript - 内联 jquery 数据赋值

javascript - JavaScript 中的 MessageFormat(本地化 UI 字符串中的参数)

javascript - 从主干集合加载完整日历事件会破坏下一个和上一个功能

javascript - 使用map进行迭代时在哪里实现我的函数?

php - 通过单个复选框传递多个变量

javascript - 检查 Phonegap 应用程序连接

javascript - 带有 KML 图层的 Google Maps API,如何添加搜索框?

javascript - 如何在 jQuery 中比较 Div 的值