Advanced template compiler with deep variable resolution, object processing, and strict validation with circular reference protection.
- Deep Variable Resolution: Access nested properties using dot notation (e.g.,
{{user.profile.name}}) - Object/Array Processing: Automatically handle complex data structures
- Strict Mode: Validate template variables and throw errors for missing values
- Custom Resolvers: Extend functionality with custom variable resolution logic
- Circular Reference Protection: Prevent infinite loops with depth limiting
- TypeScript Support: Full type safety and autocompletion
- Customizable Variable Pattern: Use your own regex pattern for variable matching
npm install templon
# or
yarn add templon
# or
pnpm add templonimport { compileTemplate } from "templon";
// Simple string interpolation
const result = compileTemplate("Hello {{name}}", { name: "World" });
// Output: "Hello World"
// Nested object access
const result = compileTemplate("Hello {{user.profile.name}}", {
user: {
profile: {
name: "John",
},
},
});
// Output: "Hello John"
// Array access
const result = compileTemplate("First user: {{users.0.name}}", {
users: [{ name: "John" }, { name: "Jane" }],
});
// Output: "First user: John"Note: The template engine uses radash under the hood for deep property access, which provides safe and efficient object traversal.
const template = "Users: {{users}}";
const data = {
users: ["John", "Jane", "Bob"],
};
const result = compileTemplate(template, data);
// Output: "Users: John,Jane,Bob"const template = "Hello <name>";
const result = compileTemplate(
template,
{ name: "World" },
{ variablePattern: /<([^{}]+)>/g }
);
// Output: "Hello World"const template = "Hello {{name}}";
try {
compileTemplate(template, {}, { strict: true });
} catch (error) {
// Error: Missing variable: name
}const template = "Hello {{user.name}}";
const result = compileTemplate(
template,
{},
{
resolver: (path) => {
if (path === "user.name") return "Custom User";
return undefined;
},
}
);
// Output: "Hello Custom User"| Option | Type | Default | Description |
|---|---|---|---|
| strict | boolean | false | Throw errors when variables are missing |
| preserveUndefined | boolean | false | Preserve undefined variables in output |
| autoStringifyObjects | boolean | true | Automatically stringify objects to JSON |
| parseStrings | boolean | true | Automatically parse strings in output |
| parseBinInts | boolean | false | Automatically parse BigInts in output |
| resolver | (path: string) => any | undefined | Custom variable resolver function |
| stringTransform | (value: string) => string | (s) => s | Transform function for final string output |
| maxVariableDepth | number | 10 | Maximum depth for variable resolution |
| variablePattern | RegExp | /{{([^{}]+)}}/g | Custom regex pattern for variable matching |
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
