import { Input } from " dreamkit " ;
Type-safe and/or controlled input component.
Controlled components are well known in the React community but are not
available in Solid.js as it does not work with a virtual DOM.
While it is possible to emulate the behaviour of a controlled component with
the ‘onInput’ listener, it is not really possible and there are many cases
where the component is no longer controlled.
With the Input component it is possible to control its value and also ensure
TypeScript typing based on the field type.
Definition import type { JSXElement, ComponentProps } from " solid-js " ;
type OverrideProps< T , U > = Omit < T , keyof U > & U ;
value ?: any | ( () => any );
onChange ?: ( value : any ) => void ;
onNativeChange ?: ComponentProps < " input " >[ " onChange " ];
Examples Controlled text import { $route, Input } from " dreamkit " ;
import { createSignal } from " solid-js " ;
export default $route . path ( " / " ) . create ( () => {
const [ name , setName ] = createSignal ( "" );
< Input value = {name} onChange = {(value) => setName ( value.toUpperCase( ) )} />
Controlled number import { $route, Input } from " dreamkit " ;
import { createEffect, createSignal } from " solid-js " ;
export default $route . path ( " / " ) . create ( () => {
const [ number , setNumber ] = createSignal < number | null > ( 0 );
createEffect ( () => console . log ( " number " , number ()));
< p > value : {JSON . stringify ( number () )}</ p >
if (value === null || value < 100 ) setNumber (value);
Controlled checkbox import { $route, Input } from " dreamkit " ;
import { createSignal } from " solid-js " ;
export default $route . path ( " / " ) . create ( () => {
const [ bool , setBool ] = createSignal ( false );
< p > value : {JSON . stringify ( bool () )}</ p >
< Input type = " checkbox " value = {bool} onChange = {setBool} />
Controlled file import { $route, Input } from " dreamkit " ;
import { createEffect, createSignal } from " solid-js " ;
export default $route . path ( " / " ) . create ( () => {
const [ file , setFile ] = createSignal < File | null > ( new File ([] , " file.txt " ));
createEffect ( () => console . log ( " file " , file ()));
< p > value : { file () ?.name}</ p >
< Input type = " file " value = {file} onChange = {setFile} />
Uncontrolled text import { $route, Input } from " dreamkit " ;
export default $route . path ( " / " ) . create ( () => {
onChange = {(value) => console.log( " value " , value)}