跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
JavaScript大前端

前端监控实践:错误、性能与行为监控指南

综述由AI生成前端监控的重要性及实施方法。通过对比无监控的错误处理与使用 Sentry 的正确实践,阐述了如何集成错误监控、性能指标(如 CLS, FID, LCP)以及用户行为追踪。旨在帮助开发团队主动发现生产环境问题,减少用户反馈延迟,提升应用稳定性。

NodeJser发布于 2026/4/6更新于 2026/6/230 浏览

前端监控实践

为什么需要前端监控

在生产环境中,若缺乏有效的监控机制,应用崩溃可能持续数小时而开发团队无从知晓。主动监控是保障用户体验的关键。

反面教材
// 反面教材:没有监控
// components/Checkout.jsx
export default function Checkout() {
  const [loading, setLoading] = useState(false);
  const handleSubmit = async () => {
    setLoading(true);
    try {
      await api.checkout();
    } catch (error) {
      console.error('Checkout failed:', error);
      setError('支付失败');
    } finally {
      setLoading(false);
    }
  };
  return (
    <button onClick={handleSubmit} disabled={loading}>
      {loading ? '支付中...' : '支付'}
    </button>
  );
}

问题:错误仅在控制台打印,开发团队无法感知,用户遇到问题只能截图反馈。

前端监控的正确姿势

1. 错误监控
// 正确姿势:Sentry 错误监控
// src/utils/errorMonitoring.js
import * as Sentry from '@sentry/react';

export function initSentry() {
  Sentry.init({
    dsn: 'YOUR_SENTRY_DSN',
    integrations: [
      new Sentry.BrowserTracing(),
      new Sentry.Replay()
    ],
    tracesSampleRate: 1.0,
    replaysSessionSampleRate: 0.1
  });
}

export function captureError(error) {
  Sentry.captureException(error);
}

export function captureMessage(message) {
  Sentry.captureMessage(message);
}

使用示例:

// components/Checkout.jsx
import { captureError } from '../utils/errorMonitoring';

const handleSubmit = async () => {
  try {
    await api.checkout();
  } catch (error) {
    captureError(error);
    setError('支付失败');
  }
};
2. 性能监控
// 正确姿势:性能监控
// src/utils/performanceMonitoring.js
import { getCLS, getFID, getFCP, getLCP, getTTFB } from 'web-vitals';

export function initPerformanceMonitoring() {
  getCLS(console.log);
  getFID(console.log);
  getFCP(console.log);
  getLCP(console.log);
  getTTFB(console.log);
}

// 集成到 Sentry
import * as Sentry from '@sentry/react';

export function sendToSentry({ name, delta, id }) {
  Sentry.metrics.distribution(name, delta, { tags: { id } });
}

getCLS(sendToSentry);
getFID(sendToSentry);
getLCP(sendToSentry);
3. 用户行为监控
// 正确姿势:用户行为监控
// src/utils/userMonitoring.js
import * as Sentry from '@sentry/react';

export function trackEvent(eventName, data) {
  Sentry.captureEvent({ message: eventName, extra: data });
}

export function trackClick(element, eventName) {
  element.addEventListener('click', () => {
    trackEvent(eventName, { timestamp: new Date().toISOString() });
  });
}

使用示例:

// components/Button.jsx
import { trackClick } from '../utils/userMonitoring';

export default function Button({ onClick, children }) {
  const buttonRef = useRef(null);
  useEffect(() => {
    if (buttonRef.current) {
      trackClick(buttonRef.current, 'button_clicked');
    }
  }, []);
  return (
    <button ref={buttonRef} onClick={onClick}>
      {children}
    </button>
  );
}

目录

  1. 前端监控实践
  2. 为什么需要前端监控
  3. 反面教材
  4. 前端监控的正确姿势
  5. 1. 错误监控
  6. 2. 性能监控
  7. 3. 用户行为监控
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • GitHub 开发者画像深度解析与效能提升指南
  • WebStorm 安装与首次配置指南
  • AIGC 大模型工程师与产品经理核心能力成长路径
  • 设计模式:观察者模式详解与 Java 实现
  • ROS2 中的 TF 系统:机器人坐标系管理
  • 企业级私有化 AI 部署:大模型原理与本地智聊机器人实战
  • 人工智能应用工程师(高级)课程体系与报考流程解析
  • 算法实战:Z 字形变换与外观数列详解
  • 基于 Coze Skills 与 OpenClaw 的 AI 智能体自动化实战指南
  • 2026 年前端行业现状:是夕阳还是新机遇
  • Elasticsearch 与 Kibana 实战:从部署到 C++ 客户端封装
  • 三款主流云电脑部署 DeepSeek 大模型性能对比评测
  • 多分类Logit回归原理及分析结果指标解读
  • YOLOv8OBB 旋转目标检测在 RK3588 上的 C++ 部署
  • MySQL 表约束核心指南:从基础到外键实战
  • 攻防世界 Web 题解:SQL 注入与文件包含漏洞分析
  • VS Code + WSL 环境下 GitHub 访问与 Copilot 连接问题解决方案
  • 位运算实战:判断字符唯一性与查找缺失数字
  • 云原生算力调度:基于 Kubernetes 的智能资源分配
  • 网络安全入门:黑客技术体系与自学路径解析

相关免费在线工具

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

  • JavaScript 压缩与混淆

    Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online