# cache-per-frame
**Repository Path**: mirrors_jsantell/cache-per-frame
## Basic Information
- **Project Name**: cache-per-frame
- **Description**: Cache the result of a function once per frame
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2020-09-25
- **Last Updated**: 2026-05-17
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# cache-per-frame
[](https://travis-ci.org/jsantell/cache-per-frame)
[](https://www.npmjs.org/package/cache-per-frame)
[](https://www.npmjs.org/package/cache-per-frame)
[](https://www.npmjs.org/package/cache-per-frame)
Cache the result of a function once per frame. Built for `VRDisplay.getFrameData(frameData)`
when working with several third party modules that call this once per frame. Does **not**
memoize via arguments, but only uses the arguments from the first call to the wrapped
function per frame.
## Install & Usage
Use the browser-ready bundle at [dist/cache-per-frame.js]:
```html
```
Or install via npm/yarn:
`$ npm install cache-per-frame --save`
```js
const cachePerFrame = require('cache-per-frame');
var nativeGetFrameData = VRDisplay.prototype.getFrameData;
VRDisplay.prototype.getFrameData = cachePerFrame(function (fd) {
return nativeGetFrameData.call(this, fd);
});
```
## API
The root module is a function `cachePerFrame(fn)` that takes a function `fn` and returns
a new wrapped form of that function that is throttled per frame. This wrapped function
also has two additional methods for stopping and starting the throttling. By default,
the wrapped function is already started.
### wrappedFn.stop()
Stop throttling the function calls once per frame.
### wrappedFn.start()
Start throttling the function calls once per frame.
## License
Apache License Version 2.0 (see [LICENSE])
[LICENSE]: LICENSE
[dist/cache-per-frame.js]: dist/cache-per-frame.js