说几道有意思的面试题

600 阅读1分钟

很长时间没有写博客,突然想起来现在的公司的面试题。选了比较有意思的几道题,写一篇博客谈一谈。

  1. 祖传代码的重构

题目描述:现在有一个函数Add(),里面代码很复杂实现了一系列的功能。不能不去重构他会波及太大,所以不能改函数里面的代码。但新需求是要知道在哪里调用了这个函数,这个函数被调用了多少次(count)和被实例化了多少次(newCount)。

function Add(...){
	...
}
//上面部分是不可以修改的
//在这里开始手写代码实现需求
var count = 0;
var newCount = 0;
...

提示:变量屏蔽

  1. 函数的柯里化实现

题目描述:实现一个函数go

go(d)返回god,

go()(d)返回good,

go()()(d)返回goood,

以此类推。

  1. 原生js实现MVVM
<html>
	<body>
    	<input type="text" id="input"/>
        <div id="show"></div>
    </body>
    <script>
    //实现input输入框和show 双向绑定
    ...
    </script>
</html>

提示:Vue的MVVM实现原理

  1. 实现一个简单的mixin
functiomn minxin(obj1,obj2){
    ...
}

还有好多基础的问题,都是大家面经中经常遇到的问题,在这里就不写了。

答案