<p>jquery each</p>
<p>jquery each</p>
<p>jquery each</p>
<script>
var arr = [1,2,3]
var nodeList = document.getElementsByTagName('p')
var $p = $('p')
// 要对这三个变量进行遍历,需要写三个遍历方法
// 第一
arr.forEach(function(item){
console.log(item)
})
// 第二
var i, length = nodeList.length
for(i = 0; i < length; i++) {
console.log(nodeList[i])
}
// 第三
$p.each(function (key, p){
console.log(key, p)
})
function each(data) {
var $data = $(data)
$data.each(function (key, val){
console.log(key, val)
})
}
each(arr)
each(nodeList)
each($a)
</script>
class Iterator {
constructor(container) {
this.list = container.list
this.index = 0
}
next() {
if (this.hasNext()) {
return this.list[this.index++]
}
return null
}
hasNext() {
if (this.index >= this.list.length) {
return false
}
return true
}
}
class Container {
constructor(list) {
this.list = list
}
// 生成遍历器
getIterator() {
return new Iterator(this)
}
}
let arr = [1, 2, 3, 4, 5, 6]
let container = new Container(arr)
let iterator = container.getIterator()
while(iterator.hasNext()) {
console.log(iterator.next())
}
Array.prototype[Symbol.iterator]
来测试function each(data) {
// 生成迭代器
let iterator = data[Symbol.iterator]()
console.log(iterator.next()) // 有数据时返回 { value: 1, done: false }
let item = {done: false}
while (!item.done) {
item = iterator.next()
if (!item.done) {
console.log(item.value)
}
}
}
测试代码
let arr = [1, 2, 3, 4]
let nodeList = document.getElementByTagName('p')
let m = new Map()
m.set('a', 100)
m.set('b', 200)
each(arr)
each(arr)
each(m)
// `Symbol.iterator`并不是人人都知道
// 也不是每个人都需要封装一个each方法
// 因此有了 `for...of`语法
function each(data) {
for (let item of data) {
console.log(item)
}
}
each(arr)
each(nodeList)
each(m)
// for of 遍历迭代器
// for in 遍历对象