- loop
范式
- loop
in: { [eles:|values: [, start:][, end:][, step:]][, mutable:][, cond:] }
each:
您可以通过loop来进行循环操作
属性
属性 | 类型 | 是否必须 | 备注 |
---|---|---|---|
eles | selector | x | |
values | selector | x | |
cond | expr | x | loop的执行条件 相当于java的while循环 |
start | number | x | 循环的起始值,Default = 0 |
end | number | x | Default = len of input |
step | number | x | 迭代步长, Default = 1 |
mutable | boolean | x | loop each操作后,DOM节点是否会产生变化(DOM节点有更新,或者删除)如果没有变化,将该属性设置为$false可以提高效率,Default = $true |
特殊变量
$e
循环中的当前元素
$i
循环中的当前下标
$v
循环非web element元素的数值
$count
loop size
用法
遍历eles里的节点
- loop:
in: { eles: '.list' }
each:
- echo: '$e'
区间为[start,end),每次增加步长为step,下⾯则输出1到9
- loop:
in: { start: '1', end: '10', step: '1' }
each:
- echo: '$i'
片段样例
- load: '"https://news.baidu.com/"'
- loop:
in: { eles: '#pane-news ul li' }
each:
- select: { ele: 'a', under: '$e', path: '/tmp' }
- echo: '$/tmp'