Spotify API - 自动完成搜索结果为空

Posted

技术标签:

【中文标题】Spotify API - 自动完成搜索结果为空【英文标题】:Spotify API - autocomplete search results are null 【发布时间】: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

【问题讨论】:

【参考方案1】:

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

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

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

【讨论】:

啊。好,谢谢!我在这里提到的很多答案仍在使用已弃用的 API ws.spotify.com/search/1/album.json 等,所以如果数据属性关闭,我会在脑海中浮现。

以上是关于Spotify API - 自动完成搜索结果为空的主要内容,如果未能解决你的问题,请参考以下文章

jQuery 自动完成嵌套 Ajax 调用

spotify api 获取用户的播放列表

Spotify API 更新不允许自动播放

Spotify 元数据 API:限制搜索结果

Spotify 公共搜索 API

将歌曲添加到 Spotify 队列 Android 不会自动播放下一首歌曲