强大的JavaScript! 浅浅论一下 talk in js

序言:

在强大的JS洗礼下,长安对大厂的窥探之心愈加深刻!基于上次腾讯的一道浅聊代码执行力,今天长安难耐躁动的心看看百度的风格。如何从细节之中窥探大厂的机遇?

1.敏捷的逻辑能力

无论是数据结构还是算法,其实早已脱离了普通的编写代码,更是一种对待脑力的思维逻辑的运用。 假设现在长安是个King,需要招募千只duck合唱团,为我嘎嘎演唱!如何为King引入呢?------没错,数组储存。【切记数据在JS中并非是简单数据类型,数组也是对象】执行如下:

javascript 复制代码
const choir = []; // 合唱团  数组也是对象 
        // 对象字面量 
const duck = {
            duckSign: function () {
                console.log('嘎嘎嘎');
            }
        }

引入对象choir 和 duck,将duck 具有的能力表达出来。

2.深入的语言表达能力

接下来想一想,想要进入我King的合唱团其实那么简单,并非虾兵蟹将都可以。具体要求如下:

javascript 复制代码
           function joinChoir(animal) {
            //记住严谨性 加入合唱团的要求 
            if (animal && typeof animal.duckSign == 'function') {
                choir.push(duck);
            }
            console.log('恭喜加入合唱团')
        }

我们需要将加入合唱团的要求改写成一个方法,并通过if语句进行封装,这是脱离一般其他思维的跳跃,小伙伴们可以多看看。这里表达一下,JS里不是传统的面向对象,无需用class Duck定义,而是基于原型式的面向对象。

3.执行

若是只有999只duck?

css 复制代码
for (let i = 0; i < 999; i++) {
            joinChoir(duck)
        }

动物的世界里如何找到其他animal代替duck招入到合唱团呢?

javascript 复制代码
const chicken = {
            duckSign: function () {
                console.log('嘎嘎嘎');
            }
        }

是的,用chicken代替。虽然外形不同,但我也可以招募会嘎嘎嘎的chicken不是一样的效果吗!

最后执行即可!

matlab 复制代码
        console.log('合唱团已有' + choir.length + '位成员');
        joinChoir(chicken);
        if (choir.length === 1000) {
            console.log('报告国王, 合唱团招聘完成');
        }

所以将999成功转化到1000只了!于是可以报告King,合唱团招聘完成!

总结

JS才是最面向对象的面向对象 除了简单数据类型一切都是对象 - 如何区分不同类型的对象?使用 Object.prototype.toString.call()即可完成!!!

相关推荐
老毛肚4 小时前
jeecg-boot-base-core 02 day
javascript·python
烬羽9 小时前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
半个落月10 小时前
一个新手用 Bun + Axios 调通 DeepSeek API 的实践记录
javascript
不好听61310 小时前
深入理解链表:线性数据结构的另一面
javascript·数据结构
林希_Rachel_傻希希10 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
小林ixn10 小时前
从 Ajax 到异步编程:JSON 序列化、Event Loop 与 XHR 请求完全解析
javascript
丷丩11 小时前
MapLibre GL JS第47课:添加动画图标
javascript·gis·动画·mapbox·maplibre
快乐的哈士奇12 小时前
【Next.js实战①】Gmail API 按柜号检索邮件:OAuth 双 Cookie 与搜索 Fallback
开发语言·javascript·ecmascript
云水一下12 小时前
Vue.js从零到精通系列(五):全局状态管理——Pinia 核心与实践
前端·javascript·vue.js
kmblack112 小时前
javascript计算年龄
开发语言·javascript·ecmascript