目录

前端开发之代理模式

介绍

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

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

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
uhakadotcom11 分钟前
Browser.js:轻松模拟浏览器环境
前端·面试·github
henujolly19 分钟前
es6的100个问题
前端·ecmascript·es6
北岛贰30 分钟前
🔥🔥🔥2.5W字!8个场景问题!带你了解最实用的 git 操作!!!
前端·git
Zfox_32 分钟前
【Linux】高性能网络模式:Reactor 反应堆模式
linux·服务器·c++·设计模式·性能优化·reactor
巴巴_羊35 分钟前
Banner区域
前端
倔强青铜三42 分钟前
WXT浏览器插件开发中文教程(15)----资源加载详解
前端·javascript·vue.js
随风行酱1 小时前
2022-2023 六年前端中大厂面试总结(仅题目,无答案)的答案参考
前端·javascript·面试
贩卖纯净水.1 小时前
项目实战-角色列表
开发语言·前端·javascript
IT、木易1 小时前
如何利用<ruby>、<rt>、<rp>标签实现中文注音或字符注释?
前端·html·html5
海绵波波1071 小时前
【源码阅读/Vue & Flask前后端】简历数据查询功能
前端·vue.js·flask