File: simple.md | Updated: 11/15/2025
Search...
+ K
Auto
Docs Examples GitHub Contributors
Docs Examples GitHub Contributors
Docs Examples GitHub Contributors
Docs Examples Github Contributors
Docs Examples Github Contributors
Docs Examples Github Contributors
Docs Examples Github Contributors
Docs Examples Github Contributors
Maintainers Partners Support Learn StatsBETA Discord Merch Blog GitHub Ethos Brand Guide
Documentation
Framework
Solid
Version
v5
Search...
+ K
Menu
Getting Started
Guides & Concepts
API Reference
ESLint
Examples
Plugins
Framework
Solid
Version
v5
Menu
Getting Started
Guides & Concepts
API Reference
ESLint
Examples
Plugins
Solid Example: Simple
=================================================================================================================================================================================================================================================================================================================================================================================================
Code ExplorerCode
Interactive SandboxSandbox
src
assets
index.tsx
.eslintrc.cjs
.gitignore
README.md
index.html
package.json
tsconfig.json
vite.config.ts
tsx
/* @refresh reload */
import {
QueryClient,
QueryClientProvider,
useQuery,
} from '@tanstack/solid-query'
import { SolidQueryDevtools } from '@tanstack/solid-query-devtools'
import { Match, Switch } from 'solid-js'
import { render } from 'solid-js/web'
const queryClient = new QueryClient()
export default function App() {
return (
<QueryClientProvider client={queryClient}>
<SolidQueryDevtools />
<Example />
</QueryClientProvider>
)
}
function Example() {
const state = useQuery(() => ({
queryKey: ['repoData'],
queryFn: async () => {
const response = await fetch(
'https://api.github.com/repos/TanStack/query',
)
return await response.json()
},
}))
return (
<Switch>
<Match when={state.isPending}>Loading...</Match>
<Match when={state.error}>
{'An error has occurred: ' + (state.error as Error).message}
</Match>
<Match when={state.data !== undefined}>
<div>
<h1>{state.data.name}</h1>
<p>{state.data.description}</p>
<strong>👀 {state.data.subscribers_count}</strong>{' '}
<strong>✨ {state.data.stargazers_count}</strong>{' '}
<strong>🍴 {state.data.forks_count}</strong>
<div>{state.isFetching ? 'Updating...' : ''}</div>
</div>
</Match>
</Switch>
)
}
render(() => <App />, document.getElementById('root') as HTMLElement)
/* @refresh reload */
import {
QueryClient,
QueryClientProvider,
useQuery,
} from '@tanstack/solid-query'
import { SolidQueryDevtools } from '@tanstack/solid-query-devtools'
import { Match, Switch } from 'solid-js'
import { render } from 'solid-js/web'
const queryClient = new QueryClient()
export default function App() {
return (
<QueryClientProvider client={queryClient}>
<SolidQueryDevtools />
<Example />
</QueryClientProvider>
)
}
function Example() {
const state = useQuery(() => ({
queryKey: ['repoData'],
queryFn: async () => {
const response = await fetch(
'https://api.github.com/repos/TanStack/query',
)
return await response.json()
},
}))
return (
<Switch>
<Match when={state.isPending}>Loading...</Match>
<Match when={state.error}>
{'An error has occurred: ' + (state.error as Error).message}
</Match>
<Match when={state.data !== undefined}>
<div>
<h1>{state.data.name}</h1>
<p>{state.data.description}</p>
<strong>👀 {state.data.subscribers_count}</strong>{' '}
<strong>✨ {state.data.stargazers_count}</strong>{' '}
<strong>🍴 {state.data.forks_count}</strong>
<div>{state.isFetching ? 'Updating...' : ''}</div>
</div>
</Match>
</Switch>
)
}
render(() => <App />, document.getElementById('root') as HTMLElement)
[###### Want to Skip the Docs?
Query.gg - The Official React Query Course
\
“If you’re serious about *really* understanding React Query, there’s no better way than with query.gg”—Tanner Linsley
Learn More](https://query.gg/?s=tanstack)
