为什么我在搜索其他内容时会删除以前的内容

zaq34kh6  于 2021-09-13  发布在  Java
关注(0)|答案(1)|浏览(353)

为什么在搜索其他内容时会删除以前的内容?例如,首先搜索鸡蛋并显示内容,但在搜索牛肉时,程序会删除鸡蛋并仅显示牛肉。代码:

const searchBtn = document.getElementById('search-btn');
const mealList = document.getElementById('meal');
const mealDetailsContent = document.querySelector('.meal-details-content');
const recipeCloseBtn = document.getElementById('recipe-close-btn');

// event listeners
searchBtn.addEventListener('click', getMealList);
mealList.addEventListener('click', getMealRecipe);
recipeCloseBtn.addEventListener('click', () => {
    mealDetailsContent.parentElement.classList.remove('showRecipe');
});

// get meal list that matches with the ingredients
function getMealList(){
    let searchInputTxt = document.getElementById('search-input').value.trim();
    fetch(`https://www.themealdb.com/api/json/v1/1/filter.php?i=${searchInputTxt}`)
    .then(response => response.json())
    .then(data => {
        let html = "";
        if(data.meals){
            data.meals.forEach(meal => {
                html += `
                    <div class = "meal-item" data-id = "${meal.idMeal}">
                        <div class = "meal-img">
                            <img src = "${meal.strMealThumb}" alt = "food">
                        </div>
                        <div class = "meal-name">
                            <h3>${meal.strMeal}</h3>
                            <a href = "#" class = "recipe-btn">Get Recipe</a>
                        </div>
                    </div>
                `;
            });
            mealList.classList.remove('notFound');
        } else{
            html = "Sorry, we didn't find any meal!";
            mealList.classList.add('notFound');
        }

        mealList.innerHTML = html;
    });
}
mklgxw1f

mklgxw1f1#

这是因为每次都要替换meallist元素中的内容。
一个简单的解决方法是在更新innerhtml值之前检索它。
差不多

let html = mealList.innerHTML;

与其每次调用函数都以空开头,不如这样做。

相关问题