30 lines
849 B
TypeScript
30 lines
849 B
TypeScript
|
import { isArray, isString, isObject } from '@vue/shared'
|
||
|
|
||
|
export function renderList(
|
||
|
source: unknown,
|
||
|
renderItem: (value: unknown, key: string | number, index?: number) => void
|
||
|
) {
|
||
|
if (isArray(source) || isString(source)) {
|
||
|
for (let i = 0, l = source.length; i < l; i++) {
|
||
|
renderItem(source[i], i)
|
||
|
}
|
||
|
} else if (typeof source === 'number') {
|
||
|
for (let i = 0; i < source; i++) {
|
||
|
renderItem(i + 1, i)
|
||
|
}
|
||
|
} else if (isObject(source)) {
|
||
|
if (source[Symbol.iterator as any]) {
|
||
|
const arr = Array.from(source as Iterable<any>)
|
||
|
for (let i = 0, l = arr.length; i < l; i++) {
|
||
|
renderItem(arr[i], i)
|
||
|
}
|
||
|
} else {
|
||
|
const keys = Object.keys(source)
|
||
|
for (let i = 0, l = keys.length; i < l; i++) {
|
||
|
const key = keys[i]
|
||
|
renderItem(source[key], key, i)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|