前端开发之代理模式

介绍

代理模式是一种结构型设计模式,它通过为一个对象提供一个代理对象来控制对该对象的访问。代理对象可以在访问真实对象之前或之后添加一些额外的操作。

TypeScript 复制代码
class RealImg {
  fileName: string;
  constructor(fileName: string) {
    this.fileName = fileName;
  }
  disPlay() {
    this.loadFromDist()
    console.log("disPlay:", this.fileName)
  }
  private loadFromDist(){
    console.log("loading:", this.fileName)
  }
}

class ProxyImg{
  realImg: RealImg

  constructor(fileName: string) {
    this.realImg = new RealImg(fileName)
  }
  display(){
    this.realImg.disPlay()
  }
}
const proxyImg = new ProxyImg('xxx.png')
proxyImg.display()
// loading: xxx.png
// disPlay: xxx.png

符合设计原则:

  • 代理和目标分离,解耦
  • 代理可自行扩展
  • 目标也可自行扩展

场景

(1)DOM事件代理(委托)

事件绑定到父容器上,而非目标节点。适合目标较多或者数量不确定(入无限加载的瀑布流图片列表)

TypeScript 复制代码
<div id="container">
  <a href="#">a1</a>
  <a href="#">a2</a>
  <a href="#">a3</a>
  <a href="#">a4</a>
</div>

const container = document.getElementById("container");
if (container) {
  // DOM 事件代理(委托)
  container.addEventListener("click", (event) => {
    const target = event.target as Element;
    if (target.nodeName === "A") {
      alert(target.innerHTML);
    }
  });
}

(2)webpack devServer proxy

正向代理(客户端代理)。开发环境,前端请求服务器 API,代理本地服务器,或者 mock 接口。

编辑vite.config.ts

TypeScript 复制代码
server: {
  port: 3000,
  proxy: {
    "/api": {
      target: "http://localhost:8888",
      /** 是否启用websockets */
      ws: true,
      /** 是否允许跨域 */
      changeOrigin: true
    }
  },
}

编辑 index.ts

TypeScript 复制代码
<script lang="ts" setup>
import { onMounted } from "vue";
import axios from "axios";

onMounted(() => {
  document.getElementById("btn1")?.addEventListener("click", () => {
    axios.get("/api/getInfo").then((res) => {
      console.log("res", res);
    });
  });
});
</script>
<template>
  <div id="container">
    <button id="btn1">发送请求</button>
  </div>
</template>

编辑服务 server.js 文件,执行 node server.js

javascript 复制代码
import http from "http";
http
  .createServer(function (req, res) {
    if (req.url === "/api/getInfo") {
      res.end("info");
    } else {
      res.end("hello");
    }
  })
  .listen(8888);

启动前端服务后,访问 http://localhost:3000 点击"发送请求"

(3)Nginx 反向代理(服务端代理)

  1. 将上述 vite+typescript 前端项目打包成 dist(vite.config.ts 配置 base: "dist"),放入nginx的 www 目录。

  2. 配置nginx

bash 复制代码
server {
    listen       8080;
    server_name  localhost;
    #charset koi8-r;
    #access_log  logs/host.access.log  main;
    location / {
        root   html;
        index  index.html index.htm;
    }
    location /api {
        proxy_pass http://127.0.0.1:8888;
    }
}
  1. 启动 nginx
bash 复制代码
> brew services start nginx 
==> Successfully started `nginx` (label: homebrew.mxcl.nginx)
  1. 控制台执行 node server.js,启动上述 server.js 文件。

  2. 页面访问 http://localhost:8080/dist

相关推荐
小小前端_我自坚强几秒前
前端踩坑指南 - 避免这些常见陷阱
前端·程序员·代码规范
lichenyang4532 分钟前
从零实现JSON与图片文件上传功能
前端
WebGirl5 分钟前
动态生成多层表头表格算法
前端·javascript
hywel29 分钟前
一开始只是想整理下书签,结果做成了一个 AI 插件 😂
前端
傅里叶33 分钟前
SchedulerBinding 的三个Frame回调
前端·flutter
小小前端_我自坚强34 分钟前
React Hooks 使用详解
前端·react.js·redux
java水泥工41 分钟前
基于Echarts+HTML5可视化数据大屏展示-车辆综合管控平台
前端·echarts·html5·大屏模版
aklry1 小时前
elpis之学习总结
前端·vue.js
笔尖的记忆1 小时前
【前端架构和框架】react中Scheduler调度原理
前端·面试
_advance1 小时前
我是怎么把 JavaScript 的 this 和箭头函数彻底搞明白的——个人学习心得
前端