Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/malchata/timenstein
A simpler way to gather user timings.
https://github.com/malchata/timenstein
Last synced: about 1 month ago
JSON representation
A simpler way to gather user timings.
- Host: GitHub
- URL: https://github.com/malchata/timenstein
- Owner: malchata
- Created: 2020-03-13T17:12:52.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T16:36:21.000Z (about 2 years ago)
- Last Synced: 2024-11-01T05:02:17.261Z (3 months ago)
- Language: JavaScript
- Size: 474 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Timenstein
ES5 (.js) version
ES6 (.mjs) version
Timenstein is a very small framework that simplifies working with the [User Timing API](https://www.w3.org/TR/user-timing-3/). The User Timing API is very useful for profiling JavaScript performance in applications, but working with it can be (IMO) unwieldy at times. I made Timenstein to simplify working with it as much as possible.
## How does User Timing work?
The User Timing API consists of two pieces of functionality: marks and measures. Let's recap what these are.
_Marks_ are used to mark specific spots in the [performance timeline](https://developer.mozilla.org/en-US/docs/Web/API/Performance_Timeline) in a page's life cycle. Marks are the simplest aspect of User Timing. They can be used to develop custom metrics specific to your application, such as the time it takes for a user to click on a call to action, for example:
```javascript
document.getElementById("cta-button").addEventListener("click", () => {
// Define mark name
const markName = "time-to-cta-click";// Mark when the image finishes loading
performance.mark(markName);// Get the entry associated with the mark:
const markEntry = performance.getEntriesByName(markName)[0];
});
```_Measures_ are used to measure the time between marks on the performance timeline. This is useful when you want to profile the performance of some part of your application's code, such as an asynchronous operation like a fetch request from an API:
```javascript
document.getElementById("get-data").addEventListener("click", () => {
// Define mark names
const measureName = "get-data";
const startMarkName = `${measureName}-start`;
const endMarkName = `${measureName}-end`;// Mark the start point
performance.mark(startMarkName);fetch("https://bigolemoviedatabase.dev/api/movies/fargo").then(response => response.json()).then(data => {
// We have the response, now mark the end point
performance.mark(endMarkName);// Now we can measure
performance.measure(measureName, startMarkName, )
});
});
```As you can see in both examples, we have to maintain the name of each mark and then retrieve it from the performance entry buffer ourselves either via `getEntriesByName` as shown in the above example, or through a [`PerformanceObserver`](https://developer.mozilla.org/en-US/docs/Web/API/PerformanceObserver). The latter is the recommended approach, but can be problematic depending on your application architecture.
## Great, so how does Timenstein simplify this?
Like User Timing, Timenstein makes use of marks and measures, but it stores this information in its own buffer and simplifies measurements by relying on handles. In Timenstein, a handle is a unique string that it uses to organize and manage marks and measures, reducing the amount of work you would otherwise do if you worked with User Timing directly.
```javascript
import Timenstein from "timenstein";const userPerf = new Timenstein();
// Define the handle we'll use to make marks and measures
const handle = "get-data";// Mark the start point using our handle
userPerf.mark(handle);fetch("https://bigolemoviedatabase.dev/api/movies/fargo").then(response => response.json()).then(data => {
// Mark the end point using the same handle
userPerf.mark(handle);// Measure how long it took to get the data by using the same handle, only
// this time we call the `measure` method
userPerf.measure(handle);
});
```