mirror of
https://github.com/KieSun/all-of-frontend.git
synced 2024-12-12 09:54:36 +08:00
feat: update answer
This commit is contained in:
parent
941302ae89
commit
fbd0970a44
66
Answer/1 ~ 10/3.md
Normal file
66
Answer/1 ~ 10/3.md
Normal file
@ -0,0 +1,66 @@
|
||||
```js
|
||||
// 请使用原生代码实现一个Events模块,可以实现自定义事件的订阅、触发、移除功能
|
||||
const fn1 = (... args)=>console.log('I want sleep1', ... args)
|
||||
const fn2 = (... args)=>console.log('I want sleep2', ... args)
|
||||
const event = new Events();
|
||||
event.on('sleep', fn1, 1, 2, 3);
|
||||
event.on('sleep', fn2, 1, 2, 3);
|
||||
event.fire('sleep', 4, 5, 6);
|
||||
// I want sleep1 1 2 3 4 5 6
|
||||
// I want sleep2 1 2 3 4 5 6
|
||||
event.off('sleep', fn1);
|
||||
event.once('sleep', () => console.log('I want sleep'));
|
||||
event.fire('sleep');
|
||||
// I want sleep2 1 2 3
|
||||
// I want sleep
|
||||
event.fire('sleep');
|
||||
// I want sleep2 1 2 3
|
||||
```
|
||||
|
||||
今天的题目算是一道常考题了,没有一个标准解法,输出正确就行。
|
||||
|
||||
但是如果你能用上一些 ES6 的语法以及处理好一些边界问题,面试官对你的评价会更好点。
|
||||
|
||||
```js
|
||||
class Events {
|
||||
constructor() {
|
||||
this.events = new Map();
|
||||
}
|
||||
|
||||
addEvent(key, fn, isOnce, ...args) {
|
||||
const value = this.events.get(key) ? this.events.get(key) : this.events.set(key, new Map()).get(key)
|
||||
value.set(fn, (...args1) => {
|
||||
fn(...args, ...args1)
|
||||
isOnce && this.off(key, fn)
|
||||
})
|
||||
}
|
||||
|
||||
on(key, fn, ...args) {
|
||||
if (!fn) {
|
||||
console.error(`没有传入回调函数`);
|
||||
return
|
||||
}
|
||||
this.addEvent(key, fn, false, ...args)
|
||||
}
|
||||
|
||||
fire(key, ...args) {
|
||||
if (!this.events.get(key)) {
|
||||
console.warn(`没有 ${key} 事件`);
|
||||
return;
|
||||
}
|
||||
for (let [, cb] of this.events.get(key).entries()) {
|
||||
cb(...args);
|
||||
}
|
||||
}
|
||||
|
||||
off(key, fn) {
|
||||
if (this.events.get(key)) {
|
||||
this.events.get(key).delete(fn);
|
||||
}
|
||||
}
|
||||
|
||||
once(key, fn, ...args) {
|
||||
this.addEvent(key, fn, true, ...args)
|
||||
}
|
||||
}
|
||||
```
|
@ -37,11 +37,17 @@ event.fire('sleep', 4, 5, 6);
|
||||
// I want sleep2 1 2 3 4 5 6
|
||||
event.off('sleep', fn1);
|
||||
event.once('sleep', () => console.log('I want sleep'));
|
||||
event.fire('sleep');
|
||||
// I want sleep2 1 2 3
|
||||
// I want sleep
|
||||
event.fire('sleep');
|
||||
// I want sleep2 1 2 3
|
||||
```
|
||||
|
||||
发现题目有点问题,改动了一下
|
||||
|
||||
新建了一个大厂真题每日打卡群,有意愿学习打卡的再进,[打开这个二维码](https://yck-1254263422.cos.ap-shanghai.myqcloud.com/2021/03/09/16152484585655.jpg)。
|
||||
|
||||
第二题:[以下代码输出什么,为什么?](https://github.com/KieSun/fucking-frontend/issues/2),这道题目是第一题的进阶版本,更有趣了。
|
||||
|
||||
<details>
|
||||
|
Loading…
Reference in New Issue
Block a user