#javascript #arrays #json #dom
#javascript #массивы #json #dom
Вопрос:
Итак, в основном у меня есть JSON, который представляет людей (пассажиров) в титанике, и я должен фильтровать их по строковому значению части базы JSON (Embedded) на основе выбора, который вы делаете для селектора HTML. Итак, каждый человек сел на корабль в другом порту (встал на борт), и мне нужно использовать селектор HTML (id =»embarkSelect»), чтобы отфильтровать их по порту, в который они вошли.
Это один массив JSON:
'use strict';
let passengers = [{
"PassengerId": 1,
"Survived": 0,
"Pclass": 3,
"Name": "Braund, Mr. Owen Harris",
"Sex": "male",
"Age": 22,
"SibSp": 1,
"Parch": 0,
"Ticket": "A/5 21171",
"Fare": 7.25,
"Cabin": "",
"Embarked": "S"
},
Embedded — это значение, которое мне нужно использовать
Это мой HTML:
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" integrity="sha384-JcKb8q3iqJ61gNV9KGb8thSsNjpSL0n8PARn9HuZOnIxN0hoP VmmDGMN5t9UJ0Z" crossorigin="anonymous">
<script src="https://kit.fontawesome.com/74f80d89fd.js" crossorigin="anonymous"></script>
<link rel="stylesheet" href="css/style.css">
<title>Document</title>
</head>
<body>
<!-- Search form -->
<form>
<div class="form-group">
</div>
<div class="form-group">
<select class="form-control" id="embarkSelect">
<option>Choose</option>
<option>C = Cherbourg</option>
<option>Q = Queenstown</option>
<option>S = Southampton</option>
</select>
</div>
</form>
<input type="text" id="txtFiltro">
<section id="sctCards">
</section>
<script src="js/passengers.js"></script>
<script src="js/logic.js"></script>
<script src="https://code.jquery.com/jquery-3.5.1.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C OGpamoFVy38MVBnE IbbVYUew OrCXaRkfj" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js" integrity="sha384-9/reFTGAW83EW2RDu2S0VKaIzap3H66lZH81PoYlFhbGU 6BZp6G7niu735Sk7lN" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js" integrity="sha384-B4gt1jrGC7Jh4AgTPSdUtOBvfO8shuf57BaghqFfPlYxofvL8/KUEfYiJOMMV rV" crossorigin="anonymous"></script>
</body>
</html>
это мой основной JS:
'use strict';
const seccCards = document.querySelector('#sctCards');
const inputFiltro = document.querySelector('#txtFiltro');
const imprimirCards = () => {
seccCards.innerHTML = '';
let filtro = inputFiltro.value.toLowerCase();
passengers.forEach(obj_passenger => {
if (obj_passenger.Name.toLowerCase().includes(filtro)) {
let card = document.createElement('div');
card.classList.add('card');
let passengerbeen = document.createElement('h2');
passengerbeen.innerText = obj_passenger.Name;
if (obj_passenger.Survived == 0) {
passengerbeen.classList.add('fas');
passengerbeen.classList.add('fa-skull');
}
let passengerF = document.createElement('p');
var survivalStatus;
if (obj_passenger.Survived == 1) {
survivalStatus = "sobrevivio";
} else {
survivalStatus = "fallecido";
}
passengerF.innerHTML = survivalStatus;
let voyage = document.createElement('p');
var voyageEmbark = " ";
if (obj_passenger.Embarked == "C") {
voyageEmbark = "Cherbourg";
} else if (obj_passenger.Embarked == "Q") {
voyageEmbark = "Queenstown";
} else {
voyageEmbark = "Southampton";
}
voyage.innerHTML = voyageEmbark;
if (obj_passenger.Embarked == ("C") amp;amp; obj_passenger.Survived === 1) {
passengerbeen.classList.add('cSurvived');
} else if (obj_passenger.Embarked == ("C") amp;amp; obj_passenger.Survived === 0) {
passengerbeen.classList.add('cDied');
} else if (obj_passenger.Embarked == ("Q") amp;amp; obj_passenger.Survived === 1) {
passengerbeen.classList.add('qSurvived');
} else if (obj_passenger.Embarked == ("Q") amp;amp; obj_passenger.Survived === 0) {
passengerbeen.classList.add('qDied');
} else if (obj_passenger.Embarked == ("S") amp;amp; obj_passenger.Survived === 1) {
passengerbeen.classList.add('sSurvived');
} else {
passengerbeen.classList.add('sDied');
}
let passengerSex = document.createElement('p');
var passengerGender;
if (obj_passenger.sex == "male") {
passengerGender = "hombre";
} else {
passengerGender = "mujer";
}
passengerSex.innerHTML = passengerGender;
let passengerAge = document.createElement('p');
var passengerAgeMystery = " ";
if (obj_passenger.Age.length < 1) {
passengerAgeMystery = "Edad desconocida";
} else {
passengerAgeMystery = obj_passenger.Age;
}
passengerAge.innerHTML = passengerAgeMystery;
card.appendChild(passengerbeen);
card.appendChild(passengerF);
card.appendChild(passengerSex);
card.appendChild(passengerAge);
card.appendChild(voyage);
seccCards.appendChild(card);
}
});
};
//function filterEmbark
inputFiltro.addEventListener('keyup', imprimirCards);
imprimirCards();
Итак, мне нужно знать, как подключить селектор HTML и JS для фильтрации (пассажиров), используя выбранное значение селектора HTML (id =»embarkSelect») (Embark)
Комментарии:
1. Rip Я провалил это домашнее задание xd