javascript 对yield生成器的理解

什么情况下可以使用yield,如果你后端传过来的数据量较大,你可以使用yield来进行懒加载,避免一次性的加载对前端造成卡顿,或长时间渲染等待,比较如说加载10万或几十万条数据时,前端一方面要读取一方面还要渲染

yield生成器,在函数名前加*号,返回时用yield

javascript 复制代码
function *gen(data)
{
	yield data;
	return true;
}

//使用方法
let arr=[1,2,3,4,5,6];
let splitdata=get(arr),
a=splitdata.next();
//输出数组
console.info(a.value);

//如果数据量比较大可以函数进行分割成小数组,100个为一组,如果上万条就1000个为一组,解决前端压力,每次只渲染1千,按下一页或向下滑再渲染新数据出来
function *group(data)
{
	let result=[];
        let groupItem=[];

        for(let k=0;k<data.length;k++)
        {
            if(k%100===0)
            {
                !!groupItem && result.push(groupItem);
                groupItem=[];
            }
            groupItem.push(data[k]);
        }

        result.push(groupItem);

        yield result;
        return true;
}
//arr如果有1万条以上数据,则会被分割
let splitdata2=group(arr);
let s=splitdata2.next();
for(let k=0;k<s.value.length;s++)
{
	//判断数组不为空
	if(s.value[k].length>0)
	{
		console.info(s.value[k]);
	}
}
相关推荐
前端开发爱好者14 小时前
支持 110 种文件预览!兼容 Vue、React、Svelte!
前端·javascript·vue.js
大家的林语冰16 小时前
👍 尤大重学 Webpack,Vite 8.1 再进化,打包模式复活!
前端·javascript·vite
张元清16 小时前
React useIsomorphicLayoutEffect:修掉 SSR 下的 useLayoutEffect 警告(2026)
前端·javascript·面试
PBitW16 小时前
直接让GPT每日训练我!!!😕😕😕
前端·javascript·面试
拾年27517 小时前
我用 30 行代码,搞懂了大模型是怎么"读"中文的
javascript·人工智能·llm
竹林81817 小时前
从 ethers.js 到 viem:我在一个 DeFi 看板项目中踩过的所有坑与最终方案
前端·javascript
bonechips18 小时前
Tool Use:从"缸中大脑"到 AI Agent 的技术真相
javascript·agent
秋天的一阵风18 小时前
Vue 3 里被严重低估的 API:InjectionKey
前端·javascript·vue.js
kisshyshy18 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
铁皮饭盒19 小时前
Bun 多线程有多快?postMessage 传输字符串比 Node.js 快 400 倍!
前端·javascript·后端