RPC JSON Serializer 
This serializer handles JSON payloads for the RPC Protocol and supports native data types.
Extending Native Data Types 
Extend native types by creating your own StandardRPCCustomJsonSerializer and adding it to the customJsonSerializers option.
- Define Your Custom Serializer ts- import type { StandardRPCCustomJsonSerializer } from '@orpc/client/standard' export classUser{ constructor( public readonlyid: string, public readonlyname: string, public readonlyemail: string, public readonlyage: number, ) {}toJSON() { return {id: this.id,name: this.name,email: this.email,age: this.age, } } } export constuserSerializer: StandardRPCCustomJsonSerializer = {type: 21,condition:data=>datainstanceofUser,serialize:data=>data.toJSON(),deserialize:data=> newUser(data.id,data.name,data.email,data.age), }- WARNING - Ensure the - typeis unique and greater than- 20to avoid conflicts with built-in types in the future.
- Use Your Custom Serializer ts- consthandler= newRPCHandler(router, {customJsonSerializers: [userSerializer], }) constlink= newRPCLink({url: 'https://example.com/rpc',customJsonSerializers: [userSerializer], })
Overriding Built-in Types 
You can override built-in types by matching their type with the built-in types.
For example, oRPC represents undefined only in array items and ignores it in objects. To override this behavior:
ts
import { StandardRPCCustomJsonSerializer } from '@orpc/client/standard'
export const undefinedSerializer: StandardRPCCustomJsonSerializer = {
  type: 3, // Match the built-in undefined type.
  condition: data => data === undefined,
  serialize: data => null, // JSON cannot represent undefined, so use null.
  deserialize: data => undefined,
}