0
我没有在我的第三个导航栏中使用我自己的功能创建任何选项(列表项)或获取和空选项。如果我在navBar函数中包含alert,那么它会在边缘工作,它也会创建一个包含所有选项的navBar,如果我要生成一个数组变量并手动将值插入到该数组中,而不通过我的书写函数来填充此数组。请看下面的代码。上次创建的导航栏按钮中没有列表项。使用我自己的功能
var tims = [];
//populates the array with teams
function getTeams(tims) {
$.getJSON("teams.json").done(function(data) {
var tim1 = data.sports_content.teams;
for (var i in tim1.team) {
if (tim1.team[i].is_nba_team == true) {
tims.push(tim1.team[i].city + ' ' + tim1.team[i].team_nickname);
}
}
})
return tims;
}
//function used to create a navbar
function navBar(id, header, options, cssParams, cssRed) {
var content = "<ul class= 'dropdown-menu ";
var css = "";
var css1 = "";
//setting up css for a navbar
for (var j in cssParams) {
css += cssParams[j] + " ";
}
content += css + "' >";
//creating list of css elements for navbar placement
for (var z = 0; z < cssParams.length - cssRed; z++) {
css1 += cssParams[z] + " ";
}
//alert(css1);
//creating list elements for a navbar
for (var i in options) {
content += "<li><a id ='" + id + i + "' href='#'>" + options[i] + "</a></li>";
}
content += "</ul>";
$('#nBar').append("<div class='btn-group '> <button id = '" + id + "' type='button' class='" + css1 + " btn btn-primary btn-lg dropdown-toggle ' data-toggle='dropdown' aria-haspopup='true' aria-expanded='false'>" + header + "<span class='caret'></span></button>" + content + "</div>");
//alert(content);
}
//creating three navbars , the third one appears to be empty
var tims = new Array();
tims = getTeams(tims);
navBar("func", "func", ["news", "roster", "stadium", "switch the team"], ["navMv", "options1", "col1"], 2);
navBar("nba", "Nba", ["top 10 last night", "commisioner", "info"], ["navMv", "next", "options1", "col1"], 2);
navBar("team", "team", tims, ["navMv", "next1", "options1", "col1"], 2);
如果我提醒tims[any_element]
我会得到正确的弹出。认为这值得一提。 例如,这将会给我一线队的名字,如果我要按下FUNC导航栏的第一个列表项,但球队导航栏列表为空:
$('#main').ready(function(){
var tims = new Array();
tims = getTeams(tims);
navBar("func","func",["news","roster","stadium","switch the team"],["navMv","options1","col1"],2);
navBar("nba","Nba",["top 10 last night","commisioner","info"],["navMv","next","options1","col1"],2);
navBar("team","team",tims,["navMv","next1","options1","col1"],2);
$("#func0").click(function(event){
alert(tims[0]);
event.preventDefault;
})
});
我已经更新了我的代码,现在使用您提供的Seb并感谢您的支持。尽管由于某种原因,我仍然遇到同样的问题。如果我将创建单个navBar元素放入我的网站中的任何对象的可以说单击事件函数中,我将获得使用所有团队名称创建的navBar,但由于某种原因无法通过ID访问。它工作的唯一方式是当我在navBar函数的末尾添加alert(内容)(每次页面加载时似乎运行两次),并且我可以通过它们的id访问所有itesm。任何想法为什么? – kamilucha123