Форма манипулирования DOM
элемент формы
Поле ввода, поле пароля, раскрывающееся окно, поле с несколькими вариантами выбора, поле радио
форма операции
поле ввода ввода
Получить значение параметра
var inp = document.querySelector('input')
console.log(inp.value);
inp.value = '123'
входное событие
-
вход
Запускает событие при изменении содержимого элемента ввода
var inp = document.querySelector('input')
inp.addEventListener('input',function(){
console.log(inp.value);
})
- изменять
Событие запускается, когда содержимое элемента ввода изменяется и теряет фокус
var inp = document.querySelector('input')
inp.addEventListener('change',function(){
console.log(inp.value);
})
-
размытие
Событие запускается, когда вкладка теряет фокус
-
фокус
Событие запускается, когда вкладка получает фокус
var inp = document.querySelector('input')
inp.addEventListener('blur',function(){
console.log(111111111);
})
inp.addEventListener('focus',function(){
console.log(22222222222);
})
выберите раскрывающийся список
Получить значение параметра: значение
var osel = document.querySelector('#sel')
console.log(osel.value);
osel.value = 3
Запускает событие при изменении параметра
var osel = document.querySelector('#sel')
osel.addEventListener('change',function(){
console.log(osel.value);
})
флажок радио
Я не знаю переключатель или поле с несколькими вариантами выбора на странице, нам нужно пройти через каждый переключатель или поле с несколькими вариантами выбора, чтобы установить событие, половина события использует событие щелчка или изменения, чтобы получить выбранный результат
выбранное состояние
При оценке радиоблока и блока множественного выбора вам нужно использовать js, чтобы определить, выбрана ли текущая метка, и вы можете использовать его checked
для оценки
var check = document.querySelectorAll('[name=aaa]')
console.log(check);
var checkeds = []
for(var i = 0;i<check.length;i++){
check[i].addEventListener('click',function(){
console.log(this.checked);
if(this.checked){
checkeds.push(this.value)
console.log(checkeds);
}
})
}
API-интерфейс массива
Справочный URL: Объект массива JavaScript | Учебник для начинающих
фильтр()
Пройдите массив и верните новый массив данных, который соответствует условию
var arr = [1, 2, 3, 4, 5, 6, 7, 8]
//赛选 数字大于3的所有元素
// var filArr = arr.filter(function(item,index,array){
// console.log('item:',item);
// console.log('index:',index);
// console.log(array);
// return item > 3
// })
// console.log(filArr);
var filArr2 = arr.filter(item => item > 4)
console.log(filArr2);
Применимый случай
1. Отфильтруйте товары с ценой выше 30
2. Корзина удаляет все выбранные товары, мы можем вернуть невыбранные товары и присвоить их исходному массиву.
некоторый()
Проверяет, соответствует ли какой-либо элемент в элементе массива указанному условию.
var users = [
{name:'admin',pwd:'123456'},
{name:'admin2',pwd:'123456'},
{name:'admin3',pwd:'123456'}
]
var inArr = users.some(item => item.name=='admin2'&&item.pwd == '123456')
console.log(inArr);
Сортировать()
Сортирует элементы массива.
var arr = [{id:1,price:30},{id:2,price:40},{id:3,price:70},{id:4,price:10}]
var sortArr = arr.sort((a,b)=>a.price-b.price)
console.log(sortArr);
карта()
Обрабатывает каждый элемент массива с помощью указанной функции и возвращает обработанный массив.
var arr = [{ id: 1, price: 30 }, { id: 2, price: 40 }, { id: 3, price: 70 }, { id: 4, price: 10 }]
var mapArr = arr.map(item => {
item.price *= 0.8
return item
})
console.log(mapArr);
для каждого()
Эксклюзивный обход массива вместо цикла for
数组.forEach((item,index,array)=>{
// item:数组中每次循环取出来的数据
//index:遍历的下标
//array:原数组
})
случай
function render(){
let dom = ''
goodsList.forEach(item =>{
dom += `
<a onclick="del(this)" href="javascript:;">
<dl>
<dt>
<span class="abl"></span>
<img src="${item.img}"/>
<span class="abr"></span>
</dt>
<dd>${item.title}</dd>
<dd><span>¥${item.price}.00</span></dd>
</dl>
</a>
`
})
// for (var i = 0; i < goodsList.length; i++) {
// dom += `
// <a onclick="del(this)" href="javascript:;">
// <dl>
// <dt>
// <span class="abl"></span>
// <img src="${goodsList[i].img}"/>
// <span class="abr"></span>
// </dt>
// <dd>${goodsList[i].title}</dd>
// <dd><span>¥${goodsList[i].price}.00</span></dd>
// </dl>
// </a>
// `
// }
goodsBox.innerHTML = dom
}
Тернарный оператор (расширенный)
Также известный как тернарный оператор, он используется для принятия решения о выполнении различных кодов в зависимости от условий.
条件 ? 满足条件返回值 : 不满足条件返回值
var num = prompt('请输入一个数字')
console.log(num>10 ? '大于10' : '小于10');
Применимый случай
Оценить выбранное состояние
<label class="fl" >
<span class="${item.ischecked?'spanAct':'span'}" onclick="change(${index})"></span>
</label>