|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- # once
-
- Only call a function once.
-
- ## usage
-
- ```javascript
- var once = require('once')
-
- function load (file, cb) {
- cb = once(cb)
- loader.load('file')
- loader.once('load', cb)
- loader.once('error', cb)
- }
- ```
-
- Or add to the Function.prototype in a responsible way:
-
- ```javascript
- // only has to be done once
- require('once').proto()
-
- function load (file, cb) {
- cb = cb.once()
- loader.load('file')
- loader.once('load', cb)
- loader.once('error', cb)
- }
- ```
-
- Ironically, the prototype feature makes this module twice as
- complicated as necessary.
-
- To check whether you function has been called, use `fn.called`. Once the
- function is called for the first time the return value of the original
- function is saved in `fn.value` and subsequent calls will continue to
- return this value.
-
- ```javascript
- var once = require('once')
-
- function load (cb) {
- cb = once(cb)
- var stream = createStream()
- stream.once('data', cb)
- stream.once('end', function () {
- if (!cb.called) cb(new Error('not found'))
- })
- }
- ```
-
- ## `once.strict(func)`
-
- Throw an error if the function is called twice.
-
- Some functions are expected to be called only once. Using `once` for them would
- potentially hide logical errors.
-
- In the example below, the `greet` function has to call the callback only once:
-
- ```javascript
- function greet (name, cb) {
- // return is missing from the if statement
- // when no name is passed, the callback is called twice
- if (!name) cb('Hello anonymous')
- cb('Hello ' + name)
- }
-
- function log (msg) {
- console.log(msg)
- }
-
- // this will print 'Hello anonymous' but the logical error will be missed
- greet(null, once(msg))
-
- // once.strict will print 'Hello anonymous' and throw an error when the callback will be called the second time
- greet(null, once.strict(msg))
- ```
|