从零开始:小白进阶指南——掌握腾讯级别的JS语法规范,实现面向对象追到心仪女神!!!

前言

我们虽是小白,却也有着一颗冲击百度,字节,腾讯等等大厂的强烈心脏。那就让我们来聊一聊今天的核心面向对象的 代理模式 Proxy !作为面向对象设计模式的一种,可以通过接口让对象之间互换使用,从而达到某些复杂目的,这便是代理模式的简单解释。

简介

长安认为现在我们小白们有必要提前了解一下什么是面向对象?其实简单来说在面向对象编程中,对象是指具有状态(属性)和行为(方法)的实体。然而JavaScript则是表现力最强的一种。

正文

回归正题,长安今天就用自己追求女神之路的历程跟着大家一起探索一番面向对象模式!

const 复制代码
            name: '长安',//字符串类型
            age: 20,//数值类型
            hometown: '抚州',
            girlfriend: null,//null 空
            city: undefined,//未定义
            hobbies: ['刷剧', '小说'],// 数组也是对象
            isSingle: true,//布尔值
            

哈哈,请看此处,这是长安的个人简介哦。其中的属性值长安也有在标注哦,小伙伴们可以了解一下的。

const 复制代码
            { name: '小美',
            xq: 20,
            hometown: '丰城',       
    }  

没错,这是小美,长安在校园里的某处遇见了,一见钟情的成为了长安的女神。

const 复制代码
            name: '小红',
            hometown: '抚州',
            //实现了和小美一样的接口,就可以互换
            receiverFlower: function (sender) {
                console.log('收到' + sender.name + '鲜花');
                //if (sender.name === '艾安盛'){
                console.log('啊,让我们在一起吧....');
                //}
                setTimeout(function () {
                    xm.xq = 99;
                    xm.receiverFlower(sender);
                }, 2000)
            }
        }

大家请仔细看看,长安要想追到女神,得需要送花来表达自己的爱意吧。可是害羞的长安不好意思亲自送给小美,结果找到了她的闺蜜小红,委托于她。

receiver作为函数的形参,这里应该传入一个对象进去,因为收花的人是对象,例如:ca.sendFlower(xm)

const 复制代码
            name: '小美',
            xq: 20,
            hometown: '丰城',
            receiverFlower: function (sender) {
                console.log(this.name + '收到' + sender.name + '鲜花');
                if (this.xq < 80) {
                    console.log('我想你还是算了吧');
                } else {
                    console.log('万达走一波');
                }
            }
        }

但是,大家也知道追女生容易被拒绝,何况还是女神级别的人物。这里我们注意xm.emotion,也就是小美的心情,当xm.emotion >= 80,小美才会收下长安的花,并与之谈恋爱。但长安怕被小美直接拒绝,这样很掉面子。这时候,长安想到了一个办法,先把花交给小美的室友,室友可以观察小美的心情,在心情好的时候转送给下课。在这里的时候我们的思路就打开了,我们可以通过小美的室友间接去访问小美。

代理模式

const 复制代码
            name: '小红',
            hometown: '抚州',
            //实现了和小美一样的接口,就可以互换
            receiverFlower: function (sender) {
                console.log('收到' + sender.name + '鲜花');
                //if (sender.name === '艾安盛'){
                console.log('啊,让我们在一起吧....');
                //}
                setTimeout(function () {
                    xm.xq = 99;
                    xm.receiverFlower(sender);
                }, 2000)
            }
        }

所以说代理模式这里我们定义xh这个对象,她是小美的室友小红,她跟小美有同样的方法,当长安将花送给小红时,小红会观察小美的心情,当xk.emotion >= 80 时,将花转交给小美,这样长安跟小美就可以在一起了!

而长安先将花给小红,小红在将花转交给小美,我们称之为代理模式,实现了通过代理对象控制对真实对象的访问。

最后

实现同样方法的对象(实现同样的接口),就可以互换使用,代理模式。

面向对象的编程->面向接口的编程

这就是长安的追求历程了,小伙伴们还有什么高招吗?

相关推荐
周亚鑫12 分钟前
vue3 pdf base64转成文件流打开
前端·javascript·pdf
落魄小二21 分钟前
el-table 表格索引不展示问题
javascript·vue.js·elementui
y52364822 分钟前
Javascript监控元素样式变化
开发语言·javascript·ecmascript
fruge36 分钟前
纯css制作声波扩散动画、js+css3波纹催眠动画特效、【css3动画】圆波扩散效果、雷达光波效果完整代码
javascript·css·css3
neter.asia44 分钟前
vue中如何关闭eslint检测?
前端·javascript·vue.js
嚣张农民1 小时前
JavaScript中Promise分别有哪些函数?
前端·javascript·面试
光影少年1 小时前
vue2与vue3的全局通信插件,如何实现自定义的插件
前端·javascript·vue.js
Rattenking1 小时前
React 源码学习01 ---- React.Children.map 的实现与应用
javascript·学习·react.js
熊的猫2 小时前
JS 中的类型 & 类型判断 & 类型转换
前端·javascript·vue.js·chrome·react.js·前端框架·node.js
别拿曾经看以后~4 小时前
【el-form】记一例好用的el-input输入框回车调接口和el-button按钮防重点击
javascript·vue.js·elementui