Javascript JSON DOM селектор: как мне указать JS фильтровать некоторые карточки из базы JSON в селекторе html?

#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