From: Evan You Date: Wed, 16 Oct 2019 14:42:25 +0000 (-0400) Subject: perf(v-for): use faster array population in renderList X-Git-Tag: v3.0.0-alpha.0~402 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b20b922d9943397bcd9ac33d7bde88caa84e986e;p=thirdparty%2Fvuejs%2Fcore.git perf(v-for): use faster array population in renderList --- diff --git a/packages/runtime-core/src/helpers/renderList.ts b/packages/runtime-core/src/helpers/renderList.ts index 5cd92e5b2f..0150b857ea 100644 --- a/packages/runtime-core/src/helpers/renderList.ts +++ b/packages/runtime-core/src/helpers/renderList.ts @@ -5,14 +5,16 @@ export function renderList( source: any, renderItem: (value: any, key: string | number, index?: number) => VNodeChild ): VNodeChild[] { - let ret: VNodeChild[] = [] + let ret: VNodeChild[] if (isArray(source) || isString(source)) { + ret = new Array(source.length) for (let i = 0, l = source.length; i < l; i++) { - ret.push(renderItem(source[i], i)) + ret[i] = renderItem(source[i], i) } } else if (typeof source === 'number') { + ret = new Array(source) for (let i = 0; i < source; i++) { - ret.push(renderItem(i + 1, i)) + ret[i] = renderItem(i + 1, i) } } else if (isObject(source)) { if (source[Symbol.iterator as any]) { @@ -26,5 +28,5 @@ export function renderList( } } } - return ret + return ret! }