Links & Request Batching
Similar to urql's exchanges or Apollo's links. Links enables you to customize the flow of data between tRPC Client and the tRPC-server.
Request Batching​
Request batching is automatically enabled which batches your requests to the server, this can make the below code produce exactly one HTTP request and on the server exactly one database query:
ts
ts
Customizing data flow​
The below examples assuming you use Next.js, but the same as below can be added if you use the vanilla tRPC client
Setting a maximum URL length​
When sending batch requests, sometimes the URL can become too large causing HTTP errors like 413 Payload Too Large, 414 URI Too Long, and 404 Not Found. The maxURLLength option will limit the number of requests that can be sent together in a batch.
utils/trpc.tsts
utils/trpc.tsts
Disabling request batching​
1. Disable batching on your server:​
In your [trpc].ts:
pages/api/trpc/[trpc].tsts
pages/api/trpc/[trpc].tsts
2. Use batch-free link in your tRPC Client​
utils/trpc.tstsx
utils/trpc.tstsx
Using a splitLink to control request flow​
Disable batching for certain requests​
1. Configure client / utils/trpc.ts​
utils/trpc.tstsx
utils/trpc.tstsx
2. Perform request without batching​
client.tsts
client.tsts
or:
MyComponent.tsxtsx
MyComponent.tsxtsx
Creating a custom link​
Reference examples can be found in
packages/client/src/links.
utils/customLink.tstsx
utils/customLink.tstsx