强大的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()即可完成!!!

相关推荐
Asort33 分钟前
React函数组件深度解析:从基础到最佳实践
前端·javascript·react.js
Justineo1 小时前
TemPad Dev:设计与实现
前端·javascript·css
AAA简单玩转程序设计1 小时前
救命!HTML按钮点了没反应?3分钟学会给网页“装脑子”
javascript·html
神秘的猪头1 小时前
浏览器是如何渲染 HTML/CSS/JS 页面的?——从代码到像素的完整流程
前端·javascript
啷咯哩咯啷1 小时前
el-table-v2 实现自适应列宽
前端·javascript·vue.js
3秒一个大1 小时前
JavaScript 中 var、let 和 const 的区别与应用
javascript
inx1771 小时前
微信小程序开发实战:从结构到数据绑定的完整实现
javascript·微信小程序
一枚前端小能手1 小时前
📚 JavaScript 数据类型与数据结构全攻略 - 原始值、对象、Map/Set与弱引用实战
前端·javascript
Mintopia2 小时前
🤖 通用人工智能(AGI)离 Web 应用还有多远?
前端·javascript·aigc
江城开朗的豌豆2 小时前
TypeScript泛型:让类型也"通用"的魔法
前端·javascript