Loading...
Data Transformation is a powerful feature in G6 that allows for processing and transforming data during the graph rendering process. With data transformers, you can achieve various data processing needs, such as:
Data transformation occurs at specific stages of the rendering process, allowing flexible changes to the final presentation without modifying the original data source.
Retrieve all configured data transformers in the current graph.
getTransforms(): TransformOptions;
Return Value
Example
// Retrieve all data transformersconst transforms = graph.getTransforms();console.log('Data transformers in the current graph:', transforms);
Set the data transformers for the graph, replacing all existing transformers.
setTransforms(transforms: TransformOptions | ((prev: TransformOptions) => TransformOptions)): void;
Parameters
| Parameter | Description | Type | Default | Required | 
|---|---|---|---|---|
| transforms | New data transformer configurations, or a function returning new configurations based on the current ones | TransformOptions | (prev: TransformOptions) => TransformOptions | - | ✓ | 
Note
Data transformers can process data at different stages of the graph rendering process. The set data transformations will completely replace the original ones. To add new data transformations based on existing ones, you can use functional updates.
Example 1: Set basic data transformations
graph.setTransforms(['process-parallel-edges', 'map-node-size']);
Example 2: Set data transformations with configurations
graph.setTransforms([// String form (using default configuration)'process-parallel-edges',// Object form (custom configuration){type: 'process-parallel-edges',key: 'my-process-parallel-edges',distance: 20, // Distance between parallel edges},]);
Example 3: Use functional updates
// Add new data transformations to existing configurationsgraph.setTransforms((currentTransforms) => [...currentTransforms,{type: 'map-node-size',key: 'my-map-node-size',maxSize: 100,minSize: 20,},]);
Update the configuration of a specified data transformer, identified by the key of the transformer to be updated.
updateTransform(transform: UpdateTransformOption): void;
Parameters
| Parameter | Description | Type | Default | Required | 
|---|---|---|---|---|
| transform | Configuration of the data transformer to be updated | UpdateTransformOption | - | ✓ | 
Note
To update a data transformer, the key field must be specified in the original data transformer configuration to accurately locate and update the transformer.
Example: Update data transformer configuration
// Specify key when initially setting data transformersgraph.setTransforms([{type: 'process-parallel-edges',key: 'my-process-parallel-edges',distance: 20,},]);// Update distance between parallel edgesgraph.updateTransform({key: 'my-process-parallel-edges',distance: 30,});
Data transformer configuration type, representing an array of data transformer configurations.
type TransformOptions = (CustomTransformOption | ((this: Graph) => CustomTransformOption))[];
Custom data transformer configuration interface, used to configure data processing parameters.
type CustomTransformOption = {// Data processing typetype: string;// Unique identifier for the data transformerkey?: string;// Other configuration items for different types of data processing[configKey: string]: any;};
Configuration interface for updating data transformers, used to dynamically modify data processing parameters.
type UpdateTransformOption = {// Unique identifier of the data transformer to be updatedkey: string;// Other configuration items to be updated[configKey: string]: unknown;};