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

前言

百度一面一般问的问题不会太难,但是我们要把问题答完整,答好,答到面试官的心窝窝里去是有点难度的。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的基本语言特性等等。

相关推荐
信看6 小时前
NMEA-GNSS-RTK 定位html小工具
前端·javascript·html
爱吃大芒果6 小时前
Flutter 主题与深色模式:全局样式统一与动态切换
开发语言·javascript·flutter·ecmascript·gitcode
king王一帅6 小时前
流式渲染 Incremark、ant-design-x markdown、streammarkdown-vue 全流程方案对比
前端·javascript·人工智能
liang_jy7 小时前
Android UID
android·面试
C雨后彩虹8 小时前
任务总执行时长
java·数据结构·算法·华为·面试
小鸡吃米…8 小时前
Python编程语言面试问题二
开发语言·python·面试
踢球的打工仔8 小时前
jquery的基本使用(3)
前端·javascript·jquery
徐同保8 小时前
js 点击按钮 把文本转成文件并下载下来
开发语言·javascript·ecmascript