append()不是函数jQuery

Lau*_*yer 5 javascript jquery

我是JQuery的新手(我来自Android World),我不明白为什么我会坚持,Uncaught TypeError: $list.append is not a function因为我正在操纵两个jQuery对象(据我所知).所以这是我的代码:

function transformInList(items, $list){
  if ($.isArray(items)){
      $.each(items, function(index, value){
          var $li = $('<li />');
          if (value.name && value.id){
              $li.attr('id', value.id);
              $li.text(value.name);
              $li.attr('class', 'clickableJobs')
              $list.append($li);
          }
      });
  }
}
Run Code Online (Sandbox Code Playgroud)

使用此函数调用此代码:

$(document).ready(function(){
    var $ul = ('<ul class="side-nav"></ul>');
    var jobs = {"jobs":[{"name":"Kellner", "id":"j10"}, {"name":"Fahrer", "id":"j11"}, {"name":"Lehrer", "id":"j12"}]};
    transformInList(jobs.jobs, $ul);
    $('div#jobColumn').append($ul)
});
Run Code Online (Sandbox Code Playgroud)

我的错误应该是微不足道的(就像我的代码一样),但我不明白.

谢谢你的帮助:D

Den*_*ret 9

只是一个错字.你正在传递一个字符串.

更改

var $ul = ('<ul class="side-nav"></ul>');
Run Code Online (Sandbox Code Playgroud)

var $ul = $('<ul class="side-nav"></ul>');
Run Code Online (Sandbox Code Playgroud)