什么情况下可以使用yield,如果你后端传过来的数据量较大,你可以使用yield来进行懒加载,避免一次性的加载对前端造成卡顿,或长时间渲染等待,比较如说加载10万或几十万条数据时,前端一方面要读取一方面还要渲染
yield生成器,在函数名前加*号,返回时用yield
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]);}
}