Use functions and hooks as components instead of classes. ...but without dependency lists ;)
DANGER: this library is experimental and not thoroughly tested.
NOTE: mass use of function components will result in performance degradation when compared with Glimmer components
ember install ember-function-component
# or
npm install ember-function-component
# or
yarn add ember-function-component
Example with Ember Octane
/** app/components/toggle.js
* Secret: function components are actually hooks
*/
export default function useToggle() {
const [value, setValue] = useState(false);
const toggle = useCallback(() => setValue(!value));
return { value, toggle };
}
this
will be a reference to any value returned from the function
The same SFC technique used with Glimmer components can be used with function components:
import { setComponentTemplate } from '@ember/component';
import { hbs } from 'ember-cli-htmlbars';
import { useState } from 'ember-function-component';
export default setComponentTemplate(
hbs`
{{this.value}}
<button type='button' {{on 'click' this.toggle}}>
Toggle
</button>
`,
function useToggle() {
const [value, setValue] = useState(false);
return { value, toggle: () => setValue(!value) };
}
);
Depending on the direction of ember-template-imports this syntax may be possible in the future:
import { setComponentTemplate } from '@ember/component';
import { hbs } from 'ember-cli-htmlbars';
import { useState } from 'ember-function-component';
export default function ToggleComponent() {
const [value, setValue] = useState(false);
const toggle = () => setValue(!value);
return
<template>
{{value}}
<button type='button' {{on 'click' toggle}}>
Toggle
</button>
</template>
;
}
import { useService } from 'ember-function-component';
export default function MyComponent() {
let myService = useService('some-service');
return { property: myService.something };
}
import * from 'ember-function-component'
:
useState
useCallback
useEffect
useService
- Ember.js v3.25 or above
- Node.js v12 or above
See the Contributing guide for details.
This project is licensed under the MIT License.