Post contents
We've looked at a lot of APIs in this series! Here's a cheatsheet for all the APIs we've covered to this point:
| React | Angular | Vue | Notes & Link | 
|---|---|---|---|
| function Comp() {} | @Component() class Comp {} | Comp.vueSFC file | Creates a component. | 
| createRoot(el).render(<Comp/>) | bootstrapApplication(Component) | createApp(Comp).mount('el') | Renders the component. | 
| Component function body | Class instance properties and methods | <script setup> | Where your JavaScript code goes. | 
| useEffectwith empty array | effectwith no child signals | onMounted | Side effect on component mount. | 
| <p>{val}</p> | <p>{{val}}</p> | <p>{{val}}</p> | Interpolate valinto your template. This live-updates. | 
| useState | signal | ref | State in a component. | 
| <div attr={val}> | <div [attr.attr]="val"> | <div v-bind:attr="val">or<div :attr="val"> | Attribute binding to an element. This live-updates. | 
| function Comp(props) {} | input() | defineProps(['prop']) | Component input definition. | 
| <div prop={val}> | <div [prop]="val"> | <div v-bind:prop="val">or<div :prop="val"> | Component input passing | 
| <div onEvent={fn}> | <div (event)="fn()"> | <div v-on:event="fn()">or<div @event="fn()"> | DOM event binding | 
| Pass a function as component property. | output() | defineEmits(['output']) | Component output definition. | 
| {bool && <div>} | @if (bool) {<div>} | <div v-if="bool"> | Conditional render an element. | 
| {bool ? <div/> : <div/>} | @else {} | <div v-else> | Conditionally render with an "else" clause. | 
| Multiple conditionals with different values. | @else if (other) {}or@switch&@case | <div v-else-if="other"> | Conditional render with multiple "else" clauses. | 
| {list.map(item => <div></div>)} | @for (item of list) {<div>} | <div v-for="item in list"> | Rendering a list. | 
| {list.map((item, idx) => <div></div>)} | @for (item of list; let idx = $index) {<div>} | <div v-for="(item, idx) in list"> | Get an index in a list render. | 
| <div key={item.id}> | @for (item of list; track item.id) {<div>} | <div :key="item.id"> | Using a key to distinguish element in a list. | 
| <div key={item.id}> | N/A | <div :key="item.id"> | Using a key as a render hint. | 
| Return function from a useEffectwith an empty dependency array. | effectcleanup function | onUnmountedorwatchEffectcleanup function orwatchcleanup function | Side effect cleanup on component unmount. | 
| <StrictMode> | N/A | N/A | API to ensure side effect cleanup | 
| useEffectwith no second argument | N/A | onUpdated | Listen for re-renders. | 
| useEffectwith an array of values to track | effect | watchorwatchEffect | In-component data change side effects. | 
| useLayoutEffectto run before paint | N/A due to lack of VDOM | watchwith{immediate: true}and/or{flush: "post"} | Render/paint/commit phase tracking | 
| useRef | Class property mutation | letvariable mutation | Change data without a re-render | 
| useEffectwithuseRefof previous value | effectwith class property of previous value | watchwith old and new value arguments | Listen for component property changes | 
| useMemo | computed | computed | Property-based computed values | 
| <Fragment>or<></> | <ng-container> | <template> | Transparent elements | 
| childrenproperty with a JSX value | <ng-content> | <slot> | Children injection site | 
| Named properties with a JSX value | <ng-content select="name"> | <slot name="name" /> | Named children injection site | 
| const refName = useRef()&<div ref={refName}> | viewChild() | const refName = ref()&<div ref="refName"> | Element reference that doesn't trigger reactive change | 
| <div ref={fn}> | viewChild()withafterRenderEffect | <div :ref="fn"> | Element reference that triggers reactive change | 
| useRef([])&<div ref={el => ref.current[i] = el}> | viewChildren() | ref([])&ref="refName" | Array of element references | 
| forwardRef | N/A | N/A | Allow access to a custom component | 
| useImperativeHandle | All methods and properties from the referenced component are exposed by default | defineExpose | Allow access to component's internals | 
| componentDidCatch | ErrorHandler | onErrorCaptured | Log an error | 
| getDerivedStateFromError | ErrorHandler+ parent state | onErrorCaptured+ref | Display an error | 
| createContext | InjectionTokenorInjectable | N/A | Dependency injection context creation | 
| Context.Provider | providersarray on class | provide | Dependency injection data provider | 
| useContext | inject | inject | Dependency injection data injection | 
| Enabled by default | inject(SomeVal, {optional: true}) | Enabled by default | Optional injected values | 
| Context.Providerin root component | @Injectable({ providedIn: "root" }) | providein root component | App-wide providers | 
| createPortal(<div/>, el) | DomPortalorTemplatePortal&cdkPortalOutlet | <Teleport to="body"> | Portal contents to other DOM location | 
| Custom Hooks | Signal Functions | Compositions | Logic sharing between components | 
| N/A | @Directive() | Object with special properties | Directives | 
| childrenproperty and single value passed | contentChild() | N/A | Access a reference to a single projected child | 
| Children.toArray(children) | contentChildren() | N/A | Access a reference to projected children | 
| Children.count(children) | contentChildren()&lengthproperty | N/A | Count projected children | 
| children(val) | ng-template& Template Context | <template>&v-slot | Pass values to projected children |