Ich habe eine JSON-Datei erstellt, um den Namen einer Bierliste zur Anzeige von ABV und Land aufzurufen. Die Ergebnisse können jedoch nicht auf der Webseite angezeigt werden. Ich war in der Lage, das select-Tag zu bekommen, um die Liste zu löschen, aber wenn ich ein Bier auswähle, werden nur die ausgewählten Ergebnisse als "undefiniert" angezeigt.Datenobjekte aus meiner JSON-Datei können nicht abgerufen werden
Hier ist der JS-Code, die ich bisher ... haben
var $select = $("#beerListing");
var beer = Array();
var country = Array();
$.getJSON("data.json", function(data) {
$select.html('');
for (var i = 0; i < data['beer'].length; i++)
$select.append('<option id="' + data["beer"][i]['id'] + '">' + data["beer"][i]["beer_name"] + '</option>');
for (x in data) {
if (beer.indexOf(data[x].beer_name) < 0) {
var y = beer.length;
beer[y] = data[x].beer_name;
country[y] = data[x].brewery_country;
}
}
showBeerList();
});
function showBeerList() {
var select = document.getElementById('beerListing');
for (var i = 0; i < beer.length; i++) {
var obj = document.createElement("option");
obj.text = beer[i];
obj.value = i;
select.appendChild(obj);
}
}
function getBeerInfo(picked) {
if (picked == "Pick Your Poison...") {
location.reload();
} else {
document.getElementById("name").innerHTML = beer[picked];
document.getElementById("country").innerHTML = country[picked];
}
}
HTML:
<html>
<head></head>
<body>
<h1>LCBO API TESTING</h1>
<select name="beerlist" id="beerListing" class="form-control" onchange="getBeerInfo(this.value)">
</select>
<br>
<label>Name:</label>
<label id="name">--</label>
<br>
<label>Country:</label>
<label id="country">--</label>
<br>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js"></script>
<script src="main.js"></script>
</body>
</html>
JSON Liste genannt data.json
{
"beer": [{
"beer_name": "Organic Devon Cider",
"brewery_name": "Luscombe Organic Drinks",
"beer_type": "Cider",
"beer_abv": "4.9",
"beer_ibu": "0",
"comment": "",
"venue_name": "The Anchor & Hope",
"venue_city": "London",
"venue_state": "Greater London",
"brewery_country": "England"
}, {
"beer_name": "Beer A",
"brewery_name": "Beer A",
"beer_type": "Cider",
"beer_abv": "4.9",
"beer_ibu": "0",
"comment": "",
"venue_name": "Beer",
"venue_city": "New York",
"venue_state": "New York",
"brewery_country": "USA"
}]
}
bitte auch die JSON-Datei schreiben – theCaveat
Ich werde eine kleine JSON Liste hinzufügen kurz –
@ S.Demarco i Ihre JSON fixiert ein wenig, aber sie haben kein Komma drin, ich didn Ich will das auch nicht beheben, wenn es tatsächlich so ist, wie deine Daten sind. Das ist falsch, zwischen den beiden Bierobjekten sollte ein Komma stehen}, { –