JavaScript代理模式
时间:2022-06-19
本文章向大家介绍JavaScript代理模式,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
代理模式的定义,代理是一个对象(proxy)用它来控制目标对象的访问。为此他要是先与目标对象相同的接口,但是他不同于装饰者模式,它对目标对象不进行任何修改,它的目的在于延缓"复杂"对象的初始化时间。这样可以在用到这个目标对象的时候再初始化他(对于单例来讲更是重要)。
代理模式有两种分类:
(1)普通代理
(2)惰性代理
具体看下面的例子
第一,普通代理模式
步骤一,接口检验文件的引用
//定义一个静态方法来实现接口与实现类的直接检验
//静态方法不要写出Interface.prototype ,因为这是写到接口的原型链上的
//我们要把静态的函数直接写到类层次上
//定义一个接口类
var Interface=function (name,methods) {//name:接口名字
if(arguments.length<2){
alert("必须是两个参数")
}
this.name=name;
this.methods=[];//定义一个空数组装载函数名
for(var i=0;i<methods.length;i++){
if(typeof methods[i]!="string"){
alert("函数名必须是字符串类型");
}else {
this.methods.push( methods[i]);
}
}
};
Interface.ensureImplement=function (object) {
if(arguments.length<2){
throw new Error("参数必须不少于2个")
return false;
}
for(var i=1;i<arguments.length;i++){
var inter=arguments[i];
//如果是接口就必须是Interface类型
if(inter.constructor!=Interface){
throw new Error("如果是接口类的话,就必须是Interface类型");
}
//判断接口中的方法是否全部实现
//遍历函数集合分析
for(var j=0;j<inter.methods.length;j++){
var method=inter.methods[j];//接口中所有函数
//object[method]传入的函数
//最终是判断传入的函数是否与接口中所用函数匹配
if(!object[method]||typeof object[method]!="function" ){//实现类中必须有方法名字与接口中所用方法名相同
throw new Error("实现类中没有完全实现接口中的所有方法")
}
}
}
}
步骤二,目标类
(1)图书类
//图书类
/*
* bid 图书id
* bName 图书名称
* bPrice 图书价格
* */
var Book = function(bid,bName,bPrice){
this.bid = bid;
this.bName = bName;
this.bPrice = bPrice;
}
(2)真正的目标类
//目标类
var myBookShop=(function () {
//书店里的书
var books={};
return function (bks) {
//初始化
if(typeof bks=="object"){
books=bks;
}
//加书
this.addBook = function(book){
books[book.bid] = book;
}
//找书
this.findBook=function (bid) {
if(books[bid]){
return books[bid];
}else {
return null;
}
}
//还书
this.returnBook=function (book) {
this.addBook(book);
}
//借书
this.lendBook=function (bid) {
var book=this.findBook(bid);
return book;
}
}
})();
步骤三,普通代理
var myBookShopProxy=function (bks) {
var obj=new myBookShop(bks);//类似于目标类的引用
//加书
this.addBook=function (book) {
obj.addBook(book);
}
//找书
this.findBook = function(bid){
return obj.findBook(bid);
}
//还书
this.returnBook=function (book) {
obj.returnBook(book);
}
//借书
this.lendBook=function (bid) {
return obj.lendBook(bid);
}
}
步骤四,添加数据后,开始访问
var proxy = new myBookShopProxy({
"001":new Book("001","EXTJS","45"),
"002":new Book("002","JS","60")
})
alert(proxy.lendBook("001").bName)
在普通的代理模式中,我们可以看出代理中对目标对象的引用是一次性初始化的,然后再在该基础上实现其他操作
如图:目标类和代理同时实现了同一接口。代理中一次性对目标类进行实例,然后值访问到目标类中的方法。
总结,这个代理是我们严格安装定义来写的,一般开发中不会用到,应为他没什么意义。
第二种,惰性代理----在使用时才对目标类进行初始化再引用。
对代理部分的修改如下,其余部分相同,代码如下
//惰性代理---在使用时在初始化目标类的引用
var myBookShopProxy=function (bks) {
var obj=null;
this._init=function () {
obj=new myBookShop(bks);
}
//加书
this.addBook=function (book) {
this._init();
obj.addBook(book);
}
//找书
this.findBook=function (bid) {
this._init();
obj.findBook(bid);
}
//还书
this.returnBook=function (book) {
this._init();
obj.returnBook(book);
}
//借书
this.lendBook=function (bid) {
this._init();
return obj.lendBook(bid);
}
}
修改后的代理执行过程,如图
- 用ggplot2画了一个我也叫不上名的炫酷图表
- React技巧8(不再手动绑定this,跟.bind(this)说88)
- 美美的商务范儿——ggplot2蝴蝶图
- 机器学习(三)使用Python和R语言从头开始理解和编写神经网络介绍目录神经网络背后的直观知识多层感知器及其基础知识什么是激活函数?前向传播,反向传播和训练次数(epochs)多层感知器全批量梯度下降
- React第三方组件2(状态管理之Refast的使用⑤LogicRender使用)
- 左右用R右手Python9——字符串合并与拆分
- hdu 1003 Max Sum(最大子窜和)
- React第三方组件2(状态管理之Refast的使用④中间件middleware使用)
- 高维分面应用——ggplot2分面气泡图饼图
- poj 1579 Function Run Fun
- React第三方组件2(状态管理之Refast的使用③扩展ctx)
- 财经小知识——CRS风暴与全球离岸金融中心
- The Triangle
- React第三方组件2(状态管理之Refast的使用②异步修改state)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- JavaScript里的分号,你加还是不加?
- 技术干货 | Docker 容器逃逸案例汇集
- 一张千万级别数据的表想做分页,如何优化?
- 一文学会爬虫技巧
- 为什么机器学习应用交易那么难(中)
- 消息队列的消费幂等性如何保证
- js中数组Array.reduce方法介绍及使用场景
- 推荐一套基于go开发的文档管理系统
- 如何通过容器搭建稳定可靠的私有网盘(NextCloud)
- Flutter实现倒计时功能
- Excelize 2.3.0 发布, Go 语言 Excel 基础库
- 网站渗透攻防Web篇之SQL注入攻击高级篇
- 网站渗透攻防Web篇之SQL注入攻击中级篇
- Go 语言学习之 method
- 网站渗透攻防Web篇之SQL注入攻击初级篇