前端百度一面:大厂有表现力的代码

前言

百度一面一般问的问题不会太难,但是我们要把问题答完整,答好,答到面试官的心窝窝里去是有点难度的。OK,现在给你一个情景,你能不能用代码把它描述出来。

情景描述

现在五一演出需要从动物王国中组成一支1000鸭子的合唱团,鸭子有一项技能是唱歌,请你用代码描述出来。

聪明机智的你是不是看到这里觉得这不很简单吗?看我三下五除二秒杀。相信在座的各位不久就能写出如下代码

javascript 复制代码
const choir =[]//合唱团
const duck={//鸭子
	name:'xx',
	sing:function(){//技能,唱歌
		console.log("嘎嘎嘎");
	}
}
for(let i =0;i<1000;i++){
     choir.push(duck);
 }

是不是感觉特别简单,觉得自己写的还不错,但是如果你这么写,那么可能面试官就让你回家等等了。

首先,没有封装的思想,这里我们应该把加入合唱团这个动作封装成一个方法,封装有助于降低复杂性、提高安全性和可维护性,并促进代码的重用。

scss 复制代码
function join(animal){
            choir.push(animal);
            console.log("恭喜加入");
        }
for(let i =0;i<1000;i++){
            join(duck);
        }

但是写出这样的代码还是有问题,是所有动物都能加入合唱团吗?显然不是,我们需要能嘎嘎叫的鸭子,而且我们似乎还没有作非空判断。完善一下如下

javascript 复制代码
function join(animal){
            //严谨性 加入合唱团的要求
            if(animal&&typeof animal.sing==="function"){
                choir.push(animal);
            }
            console.log("恭喜加入");
            }

这个时候我们需求变化一下,全世界只有999只鸭子,但是就是需要1000只能嘎嘎唱歌的鸭子,缺少的一只你应该怎么办?用代码描述并解决。

这个时候你能想到面试官想考你什么呢?其实这个时候我们就应该要想到JS的弱类型,这里我们可以让某一种动物去学嘎嘎叫这项技能,这样就能以假乱真,加入合唱团啦。

javascript 复制代码
const chicken ={
            name:'wm',
            sing:function(){
                console.log("gagaga");
            }
        }
join(chicken);

OK,这样我们就基本完成这道百度面试题啦。

总结

这道题主要考察了我们基本的情景编程能力和封装的思想,还考察了我们的编程习惯,是否会考虑代码的健壮性,JS的基本语言特性等等。

相关推荐
竹林81811 小时前
RainbowKit快速集成多链钱包连接,我如何从“连不上”到“丝滑切换”
前端·javascript
No8g攻城狮11 小时前
【前端】Vue 中 const、var、let 的区别
前端·javascript·vue.js
fishmemory7sec11 小时前
Vue大屏自适应容器组件:v-scale-screen
前端·javascript·vue.js
饺子不吃醋11 小时前
Promise原理、手写与 async、await
前端·javascript
zzb158012 小时前
Fragment 生命周期深度图解:从 onAttach 到 onDetach 完整流程(面试必备)
android·java·面试·安卓
红星照耀华夏13 小时前
模拟面试系列-ClassLoader
面试·职场和发展
糯米团子74913 小时前
react速通-3
javascript·react.js·前端框架
knight_9___13 小时前
Agent开发面试圣经8
面试·职场和发展
心连欣13 小时前
从静态页面到动态交互:DOM操作的核心API解析
前端·javascript·api
零瓶水Herwt13 小时前
Javascript常用设计模式
javascript