Skip to content

A SDK for web error and performance monitor. web前端错误及性能监控SDK

License

Notifications You must be signed in to change notification settings

packaaa/femonitor-web

 
 

Repository files navigation

Description

A SDK for web error and performance monitor using event subscription

Feature

  • Error observe, includes js error, unhandle rejection error, http error and resource error
  • Error sampling, support errors collection emit events for report optimization
  • Observe page performance
  • Observe user behaviors, includes console, user click event
  • Integrate rrweb
  • Hack spa router change
  • Auto report

Development

npm run watch  // Watch tsfile change and compile by rollup
npm run server // Start a nodejs server for request test

Build

npm run build

Test

npm run test

Installation

CDN

<script src="https://cdn.jsdelivr.net/npm/femonitor-web@latest/dist/index.min.js"></script>

NPM

npm i femonitor-web -S

Usage

Minimal options

import { WebMonitor } from "femonitor-web";
const monitor = Monitor.init();
/* Listen single event */
monitor.on([event], (emitData) => {});
/* Or Listen all event */
monitor.on("event", (eventName, emitData) => {})

Full options

// Default full options
export const defaultTrackerOptions = {
  env: 'dev',
  reportUrl: "",
  data: {},
  error: {
    watch: true,  // If listen all error
    random: 1,    // Sampling rate from 0 to 1, 1 means emit all error
    repeat: 5,    // Don't emit sample error events when exceed 5 times
    delay: 1000   // Delay emit event after 1000 ms
  },
  performance: false,  // If want to collect performance data
  http: {
    fetch: true,  // If listen request use fetch interface
    ajax: true    // If listen ajax request
  },
  behavior: {
    watch: false,
    console: [ConsoleType.error],
    click: true,     // If set to true will listen all dom click event
    queueLimit: 20   // Limit behavior queue to 20
  },
  /**
   * rrweb use mutation observer api, for compatibility see:
   * https://caniuse.com/mutationobserver
   */
  rrweb: {
    watch: false,
    queueLimit: 50,  // Limit rrweb queue to 20
    delay: 1000      // Emit event after 1000 ms
  },
  isSpa: true        // If watch is true, globalData can get _spaUrl for report when route change
};
const monitor = Monitor.init(defaultTrackerOptions);

Vue project

Sdk support Vue.config.errorHandler to handle error for get detail component info. You just need to call useVueErrorListener before create Vue instance.

monitor.useVueErrorListener(Vue)

React project

React supply a hook called componentDidCatch for error listen and concept called ErrorBoundary which is enabled to catch errors at top and prevent app to shutdown. You can report it by yourself like below.

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  componentDidCatch(error, info) {
    this.setState({ hasError: true });
    reportError(error, info);
  }

  render() {
    if (this.state.hasError) {
      return <h1>Something went wrong.</h1>;
    }
    return this.props.children;
  }
}

Support events

EventName Description
jsError winodw.onerror
vuejsError Vue.config.errorHandler
unhandleRejection window.onunhandledrejection
resourceError Resource request error
batchErrors Batch collection of error events, trigger every specified time interval
reqError Network request error
reqStart Network request start
reqEnd Network request end
performanceInfoReady Performance data is ready
event Includes all events above

About

A SDK for web error and performance monitor. web前端错误及性能监控SDK

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 83.8%
  • HTML 12.2%
  • JavaScript 4.0%