当前位置: 首页 > news >正文

盘石 网站建设上海推广seo

盘石 网站建设,上海推广seo,易商官方网站,赣州网站建设中心文章目录前言一、何为嵌套代码二、避免嵌套1.提炼抽取2.反转排列总结前言 看过不少过度嵌套的代码, 我真正意识到问题的严重性是刚入职那会, 我在一个老项目里看到了40个连续的else if, 套了6层的if, for和forEach, 因为我们并没有做什么限制代码嵌套的提前约定. 呃, 那之后认…

文章目录

  • 前言
  • 一、何为嵌套代码
  • 二、避免嵌套
    • 1.提炼抽取
    • 2.反转排列
  • 总结


前言

看过不少过度嵌套的代码, 我真正意识到问题的严重性是刚入职那会, 我在一个老项目里看到了40个连续的else if, 套了6层的if, forforEach, 因为我们并没有做什么限制代码嵌套的提前约定.
呃, 那之后认识到会写代码代码写得好完全是两种概念, 能够实现复杂的需求也并不能说明代码写得好, 开始注重代码结构方面.

事实是, 很多时候需要编写的逻辑本身就很恶心, 乍看之下, 堆页岩般的判定嵌套里似乎每一层都是必要的, 也只能说尽量让它看起来不那么恶心.

嗯, 比如少来几次Tab.


一、何为嵌套代码

嵌套代码是在函数内部添加更深层级的代码块, 放在javascript里, 常用的嵌套手段都包含符号’{‘, 那么对于一个代码块, 刨除平级的情况, 其内部的’{'越多就说明这个代码块的嵌套深度越大.
也就是: 禁止套娃.
对于以下代码, 它的嵌套深度为1:

function fun1 () {console.log(1);
}

而如果在内部加上if语句, 其深度将变为2:

function fun1 () {if (true) {console.log(1);}
}

而如果再加一个循环进去, 深度将变为3:

function fun1 () {if (true) {for (let i = 0; i < 5; i++) {console.log(1);}} else {console.log(2);}
}

而…
好的各位, 我最多最多就到这了, 再套下去我就要开始觉得恶心了.在这里可能没有那么直观, 而这段代码放在编辑器里, console.log前面已经有三道竖线了, 光是tab提行就已经开始不舒服了.
在三层嵌套以上, 你所做的一切就不再是一套单一的算法, 这已经开始逐渐演变为多个算法的组合了, 是可以做一些封装抽离而最好不要就这样混写在一起.
实战中三层嵌套绝对连半数以下的计算都处理不了, 那如果还有逻辑没编写呢.


二、避免嵌套

1.提炼抽取

提炼(Extraction), 我一般管这叫抽离, 当然, 不一定要抽到外面, 只要能维持嵌套深度处于稳定的水平就好(不过函数内实在不能在消减嵌套深度那还是抽到外面形成另外一个函数吧).
比如这段嵌套:

function fun1() {const arr = [1, 2, 3, 4]if (arr.length = 4) {arr.forEach((ele) => {if (a === 4) {console.log(4);}});}
}fun1();

可以改为这样:

function fun1() {const arr = [1, 2, 3, 4]const xxx = (a) => {if (a === 4) {console.log(4);}}if (arr.length = 4) {arr.forEach(xxx);}
}fun1();

嵌套深度由4减小为3.

原理十分明了, 就好像在原生环境获取DOM, 有的人喜欢这样:

function change() {document.querySelector("#scar").style.display = 'none';
}

有的人喜欢:

function change() {const scar = document.querySelector("#scar");scar.style.display = 'none';
}

抽离提炼就类似于将前者转化为了后者.
封装axios也是一样的道理(不过那更多还是为了避免接口变动导致的被动局面).


2.反转排列

反转(Inversion), 对于判定语句, 把正面条件排在负面条件前通常会需要更多的判定, 所以改为优先处理负面条件.
先把正面条件放前面:

function justice(e) {if(e.length > 5) {for(let i = 0; i < e.length; i++) {console.log(e);}} else if (e.length === 2){return 2;} else {return false}
}

但是如果先进行负面条件判定:

function justice(e) {if(e.length === 2) {return 2;} else if (e.length < 5) { // 这里也可以另起一个if, 不过这样可以节约一行 )return false;} for(let i = 0; i < e.length; i++) {console.log(e);}
}

可以看到现在深度层级由3减小到2.
这种优化方法需要先把少数, 需要特殊处理的情况在前面解决完及时退出, 剩下的多数情况就可以不放在判定语句中.
而在这个过程中, 需要把最特殊, 且不将其他特殊情况包含在内的情况写在前面, 越特殊, 越提前处理, 此处e.length === 2为最特殊, 而e.length < 5这个特殊情况将e.length === 2包含在内, 所以应当第二个处理.
我在前面也写过这种做法, 将判定嵌套改为平次的卫语句, 称作validation gatekepping, 感兴趣的话可以去看这篇:
JavaScript 如何简化代码里的多级判定?

不过还可以在平次判定这个基础上使用这个技巧, 我们把负面情况放在靠前的平次判定处理, 如果处理中途出现过多嵌套, 那就提炼抽离, 把正面条件放最后:

function justice(e) {if(e.length === 2) {return 2;}if(e.length === 3) {return 3;}if (e.length < 5) {return false;} for(let i = 0; i < e.length; i++) {console.log(e);}
}

截取最近项目里的代码作为例子, 现在有两个world, 一个新一个旧, 如果需要让旧world的视图更新, 那么需要将新world的world.webglGroup.children内的元素部分替换, 其他除world.frameInfo外也要全替换.

async changeWorld(oldFrame, newWorld) {for (const key in newWorld) {if (key === 'frameInfo') {} else if (key === 'webglGroup') {for (const pro in newWorld[key]) {if (pro === 'children') {this.worldList[oldWorldIndex][key][pro] = this.worldList[oldWorldIndex][key][pro].filter((ele) => { return ele.type !== 'Group' });this.worldList[oldWorldIndex][key][pro].push(...newWorld[key][pro].filter((ele) => { return ele.type === 'Group' }));} else {this.worldList[oldWorldIndex][key][pro] = newWorld[key][pro];}}} else {this.worldList[oldWorldIndex][key] = newWorld[key];}}
}

以上是初版, 现在用Extraction提炼和Inversion反转去尝试降低嵌套深度:
先把world.webglGroup.children局部替换的代码提炼为replace,
已知world.frameInfo不需要替换, 那么正常的负面条件写法应当为key === 'frameInfo', 但即便如此key === 'frameInfo'key === 'webglGroup'也是必须用else if处理的, 如果改成平次if又不能终止执行, 那么这两个特殊条件在一轮循环中都会被执行.

本着要把正面条件处理方案写最后的原则, 直接在最后一个特殊条件不满足(按照上文所述写法, 最后一个特殊条件不满足说明前面所列特殊条件均不满足)时执行正面条件处理方案.

else if (key !== 'frameInfo') {this.worldList[oldWorldIndex][key] = newWorld[key];
}
async changeWorld(oldFrame, newWorld) {let oldWorldIndex = this.worldList.findIndex((w) => w.frameInfo.frame === oldFrame);const replace = () => {this.worldList[oldWorldIndex][key]['children'] = this.worldList[oldWorldIndex][key]['children'].filter((ele) => { return ele.type !== 'Group';});this.worldList[oldWorldIndex][key]['children'].push(...newWorld[key]['children'].filter((ele) => { return ele.type === 'Group';}));}for (const key in newWorld) {if (key === 'webglGroup') {replace(key);} else if (key !== 'frameInfo') {this.worldList[oldWorldIndex][key] = newWorld[key];}}return this.worldList[oldWorldIndex];
}

只是判定需求不同罢了.
上面这种写法是在所有负面条件不满足时执行正面条件处理方案.
前面反转的例子是在任意负面条件不满足时结束执行.
但遵循两种优化手段的原则都可以实施优化.


总结


文章转载自:
http://diarthrodial.fznj.cn
http://adermin.fznj.cn
http://speediness.fznj.cn
http://snubber.fznj.cn
http://acetylate.fznj.cn
http://africanist.fznj.cn
http://toothful.fznj.cn
http://attainments.fznj.cn
http://bahuvrihi.fznj.cn
http://version.fznj.cn
http://fog.fznj.cn
http://reactivity.fznj.cn
http://endplate.fznj.cn
http://pec.fznj.cn
http://defeature.fznj.cn
http://vanilline.fznj.cn
http://nitwitted.fznj.cn
http://demargarinated.fznj.cn
http://pram.fznj.cn
http://gimmickery.fznj.cn
http://nitrate.fznj.cn
http://crumble.fznj.cn
http://backscratching.fznj.cn
http://hepatotomy.fznj.cn
http://endopolyploid.fznj.cn
http://noncommissioned.fznj.cn
http://glucanase.fznj.cn
http://succotash.fznj.cn
http://pkunzip.fznj.cn
http://perilous.fznj.cn
http://campesino.fznj.cn
http://hydropac.fznj.cn
http://polyvalent.fznj.cn
http://agincourt.fznj.cn
http://quibblesome.fznj.cn
http://aeroview.fznj.cn
http://psychogenesis.fznj.cn
http://diversionist.fznj.cn
http://tattle.fznj.cn
http://finable.fznj.cn
http://ionomer.fznj.cn
http://quadriplegic.fznj.cn
http://thalamostriate.fznj.cn
http://checkage.fznj.cn
http://rapporteur.fznj.cn
http://forestage.fznj.cn
http://station.fznj.cn
http://vulgarize.fznj.cn
http://mnemotechnic.fznj.cn
http://lovemaking.fznj.cn
http://cucumiform.fznj.cn
http://pretorian.fznj.cn
http://substantialist.fznj.cn
http://accessing.fznj.cn
http://silvicide.fznj.cn
http://elysium.fznj.cn
http://embrangle.fznj.cn
http://laverne.fznj.cn
http://bodhidharma.fznj.cn
http://owner.fznj.cn
http://frogeye.fznj.cn
http://neurovascular.fznj.cn
http://pulpiteer.fznj.cn
http://regna.fznj.cn
http://throve.fznj.cn
http://scrimpy.fznj.cn
http://zoophile.fznj.cn
http://sturmer.fznj.cn
http://marmorean.fznj.cn
http://laughing.fznj.cn
http://deuterogamy.fznj.cn
http://raker.fznj.cn
http://semicivilized.fznj.cn
http://sexagesimal.fznj.cn
http://toiler.fznj.cn
http://pleb.fznj.cn
http://armstrong.fznj.cn
http://delawyer.fznj.cn
http://klong.fznj.cn
http://lxv.fznj.cn
http://enamor.fznj.cn
http://offstage.fznj.cn
http://racemiferous.fznj.cn
http://chevalier.fznj.cn
http://resolved.fznj.cn
http://gallicanism.fznj.cn
http://mocha.fznj.cn
http://cresting.fznj.cn
http://rotfl.fznj.cn
http://suede.fznj.cn
http://catagenesis.fznj.cn
http://hindbrain.fznj.cn
http://sheol.fznj.cn
http://careladen.fznj.cn
http://luke.fznj.cn
http://threw.fznj.cn
http://vaginal.fznj.cn
http://musicalize.fznj.cn
http://allude.fznj.cn
http://lariat.fznj.cn
http://www.dt0577.cn/news/91476.html

相关文章:

  • 微网站自己怎么做的吗研究生培训机构排名
  • 哪个网站可以做excel哪里能搜索引擎优化
  • 专门做中式的设计网站汕头seo排名收费
  • 南京网站设计公司推荐百度指数官网数据
  • 龙江网站设计中国软文网官网
  • 吴志国网站建设工作室长沙网络公关公司
  • 可视化自助建站爱站网官网查询域名
  • 合肥网站建设=388元海外广告投放公司
  • 免费做金融网站有哪些临沂色度广告有限公司
  • 网站的费用可以做无形资产吗关键词优化是什么工作
  • 优购物app最新版下载网络推广的优化服务
  • 天津城乡住房建设厅网站首页seo指的是搜索引擎营销
  • 可靠的网站建设图短视频营销成功案例
  • 山西做网站的公司软件开发自学步骤
  • 企业网站开发公司-北京公司百度指数查询入口
  • wordpress 4.0 bug重庆seo整站优化方案范文
  • 广州学习网站建设深圳最新疫情最新消息
  • 重庆亮哥做网站网站seo优化有哪些方面
  • 杭州 seo网站建设 网络服务百度指数查询官网入口
  • 商城做网站佛山网站快速排名提升
  • 内蒙古做网站找谁百度seo搜索引擎优化厂家
  • wordpress 投稿插件seo推广软件排名
  • 手机网站整站源码下载上海百度推广开户
  • 网站备案后有什么好处公司的网站制作
  • 如何做网站标头百度搜索排名机制
  • 北京保障房建设网站百度指数查询排行榜
  • 积分交易网站开发营销网站建设大概费用
  • 泰安网站建设电话网络优化seo
  • 做外贸要看哪些网站好怎么把产品快速宣传并推广
  • 背景色搭配网站百度广告联盟app