我需要在p标签中更改结果的背景色,如果变量的结果为>则为1。 我想这可以通过if语句来完成? 这是我正在使用的代码:
const todos = [{
text: 'Order airline tickets',
completed: false
},{
text: 'Vaccine appointment',
completed: true
}, {
text: 'Order Visa',
completed: true
}, {
text: 'Book hotell',
completed: false
}, {
text: 'Book taxi to airport',
completed: true
}]
const filters = {
searchText: ''
}
const renderTodos = function (todos, filters) {
//use filter method for the title search string and save it to filters variable
const filteredTodos = todos.filter(function (todo) {
return todo.text.toLowerCase().includes(filters.searchText.toLowerCase())
})
const notDone = filteredTodos.filter(function (todo) {
return !todo.completed
})
//Empty the div containg the result, this has to be between filter and the display of the result
document.querySelector('#todos').innerHTML = ''
const summary = document.createElement('h4')
summary.textContent = `You found ${notDone.length} hits on this search that are not complete`
document.querySelector('#todos').appendChild(summary)
//loop through note object, create a p tag for the title searched and append to the div
filteredTodos.forEach(function (todo) {
const noteEl = document.createElement('p')
noteEl.textContent = todo.text
document.querySelector('#todos').appendChild(noteEl)
})
elem = document.createElement("hr")
document.querySelector('#todos').appendChild(elem)
}
document.querySelector('#search-todo').addEventListener('input', function (e) {
filters.searchText = e.target.value
renderTodos(todos, filters)
})
因此,如果我要附加到我的#todos div的p标签中也有!todo.complete,那么搜索的结果就是,只有那些p标签的p背景色应为黄色。
谢谢
答案 0 :(得分:2)
只需在if
循环中添加以下forEach
语句:
if (!todo.completed) {
noteEl.style.backgroundColor = "yellow";
}
完整循环应如下所示:
filteredTodos.forEach(function (todo) {
const noteEl = document.createElement('p');
noteEl.textContent = todo.text;
if (!todo.completed) {
noteEl.style.backgroundColor = "yellow";
}
document.querySelector('#todos').appendChild(noteEl);
})