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

相关推荐
hh随便起个名11 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
我是小路路呀11 小时前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
敲敲了个代码12 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_13 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy13 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
sg_knight13 小时前
拥抱未来:ECMAScript Modules (ESM) 深度解析
开发语言·前端·javascript·vue·ecmascript·web·esm
前端白袍14 小时前
Vue:如何实现一个具有复制功能的文字按钮?
前端·javascript·vue.js
new code Boy14 小时前
escape谨慎使用
前端·javascript·vue.js
奶球不是球14 小时前
elementplus组件中el-calendar组件自定义日期单元格内容及样式
javascript·css·css3
傻啦嘿哟15 小时前
实战:用Splash搞定JavaScript密集型网页渲染
开发语言·javascript·ecmascript