前端开发之代理模式

介绍

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

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

相关推荐
代码搬运媛8 小时前
Jest 测试框架详解与实现指南
前端
counterxing9 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq9 小时前
windows下nginx的安装
linux·服务器·前端
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜10 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai1080810 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen11 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm12 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy12 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao13 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端