【问题标题】:Spotify API - autocomplete search results are nullSpotify API - 自动完成搜索结果为空
【发布时间】:2017-02-09 01:50:21
【问题描述】:

使用 Spotify API - 我想在我输入时使用 jQuery 自动完成包含艺术家的字段。到目前为止,我正在处理以下内容:

HTML:

<input type="text" class="text-box" placeholder="Enter Artist" id="artist-input"> 

Javascript:

$(document).ready(function() {

  $("#artist-input").autocomplete({
    source: function(request, response) {
        $.ajax({
            type: "GET",
            url: "https://api.spotify.com/v1/search",
            dataType: "json",
            data: {
                type: "artist",
                limit: 3,
                contentType: "application/json; charset=utf-8",
                format: "json",
                q: request.term
            },
            success: function(data) {
                response($.map(data.artists, function(item) {
                    return {
                        label: item.name,
                        value: item.name,
                        id: item.id
                    }
                }));
            }
        });
    },
    minLength: 3,
    select: function(event, ui) {
        $("#artist-input").val(ui.item.value);
        window.location.href = "#" + ui.item.value;
    },
});

});

运行这个,结果:

functions.js:35 Uncaught TypeError: Cannot read property 'name' of null

所以我的问题是我是否需要在此过程运行之前进行某种身份验证?我的思考过程是它正在拨打电话,但它返回为空,我错过了一个额外的步骤......

这是一个带有此示例的代码笔:http://codepen.io/anon/pen/PGKLpj

【问题讨论】:

    标签: javascript jquery api spotify


    【解决方案1】:

    您使用的数据的结构略有不同。它是 data.artists.items 而不是 data.artists。如果你遍历正确的属性,它就可以正常工作。

    看看这支笔:http://codepen.io/anon/pen/qaXvob

    注意:有时只需要console.log(data); 来查看 json 结构是否与您认为的相符。

    【讨论】:

    • 啊。好,谢谢!我在这里提到的很多答案仍在使用已弃用的 API ws.spotify.com/search/1/album.json 等,所以如果数据属性关闭,我会在脑海中浮现。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-05-20
    • 2015-02-26
    • 1970-01-01
    • 2014-09-16
    • 2018-02-04
    • 1970-01-01
    • 2012-07-01
    相关资源
    最近更新 更多