分支判断的优化 (创建map等会存在性能问题 此处单文字switch判断性能更佳 )
function speack(name){
if(name=='张三'){
console.log('张三13岁')
}else if(name=='李四'){
console.log('李四14岁')
}else if(name=='李王五'){
console.log('李王五14岁')
}else{
console.log('未成年')
}
}
//多个分支判断 则 可以使用map映射
function speack1(name){
const map ={
'张三':'张三13岁',
'李四':'李四14岁',
'李王五':'李王五14岁',
}
if(map[name]){
console.log(map[name])
}else{
console.log('未成年')
}
}
// 多个分支判断且判断后做的事件不一致 则map 值可以是func
function speack1(name){
const map ={
'张三':()=>{
console.log('张三')
},
'李四':()=>{
console.log('张三')
let na ='okok'
},
'李王五':()=>{
let na ='okok'
},
}
if(map[name]){
map[name]()
}else{
console.log('未成年')
}
}
// 多个分支判断且 判断的条件不是一个字符串 判断后做的事件不一致 值则可构建数组
function speack1(name){
const list =[
[
()=>name.includes('三'),
()=> console.log('人就是张三杀的'),
],
[
()=>name.includes('李四'),
()=> console.log('李四偷东西'),
],
[
()=>name==='李王五',
()=> console.log('李王吃饭'),
]
]
let findList = list.find(item=>item[0]())
if(findList){
findList[1]()
}else{
console.log('未成年')
}
}
2023-06-15
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...