martijnvdb/type-vault 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

martijnvdb/type-vault

Composer 安装命令:

composer require martijnvdb/type-vault

包简介

Validated types for PHP: Email, UUID, URL, and more

README 文档

README

Type Vault is a TypeScript utility package that provides robust and validated types for common structured values like UUIDs, URLs, ISO date-times, hex colors, and more. It helps enforce correctness at runtime while maintaining strong typing at compile time.

✨ Features

  • ✅ Runtime and compile time validation
  • 🧪 Built-in helpers for immutability and nullability

🧑‍💻 How to use

📥 Basic Usage

Create a validated Email instance and access or update its value:

use Martijnvdb\TypeVault\Email;

$email = new Email("user@example.com");
echo $email->value; // 'user@example.com'

// Update the value with another valid email
$email->value = "foo@bar.com";
echo $email->value; // 'foo@bar.com'

❓ Nullable Variant

Use ::nullable() or pass new TypeOptionsDTO(nullable: false) to allow null as a valid value:

use Martijnvdb\TypeVault\Email;

$nullable = Email::nullable();
// Or:
$nullable = new Email(null, new TypeOptionsDTO(nullable: false));

echo $nullable->value; // null

// Set a valid email later
$nullable->value = "user@example.com";
echo $nullable->value; // 'user@example.com'

🔒 Immutable Variant

Use ::immutable() or pass new TypeOptionsDTO(immutable: true) to prevent value changes after initialization:

use Martijnvdb\TypeVault\Email;

$immutable = Email::immutable("user@example.com");
// Or:
$immutable = new Email("user@example.com", new TypeOptionsDTO(immutable: true));

echo $immutable->value; // 'user@example.com'

// Attempting to change the value throws a TypeVaultValidationError
$immutable->value = "another@example.com"; // ❌ Throws error

🧰 Supported Types

Type Vault offers a rich set of validated. Each type enforces strict formatting and value constraints at runtime, and all values are stored in a normalized form to ensure consistency and predictability across your application.

🎨 Color Types

For working with color values in various formats:

  • ColorHex – Hexadecimal color code (e.g. '#ffcc00ff', '#ffcc00' or '#fc0')
  • ColorRgb – RGB color object (e.g. 'rgb(255 128 0 / 100%)', 'rgb(255, 128, 0)' or 'rgb(255 128 0 / 1)')
  • ColorHsl – HSL color object (e.g. 'hsl(360 0 0 / 1)' or 'hsl(360deg 0% 0% / 100%)')
  • ColorOklch – OKLCH color object (e.g. 'oklch(70 0.4 120deg / 25%)', 'oklch(70% 100% 120deg / 0.25)' or 'oklch(0.7 0.4 120 / 25%)')

🕒 Temporal Types

For representing and validating time-related values:

  • DateOnly – ISO date string without time (e.g. '2023-01-02' or '2023-1-2')
  • DateTime – ISO UTC date-time string (e.g. '2023-01-02T01:23:45.123Z' or '2023-01-02T01:23:45Z')
  • TimeOnly – ISO time string without date (e.g. '01:23:45.123' or '01:23:45')
  • Duration – ISO 8601 duration string (e.g. 'PT1H30M')
  • Month – Valid month name or number (e.g. 'january' or december)
  • Weekday – Valid weekday name (e.g. 'monday')
  • Year – Valid four-digit year (e.g. '2025')

🌐 Communication Types

For validating contact and identity formats:

  • Email – RFC-compliant email address (e.g. 'user@example.com')
  • PhoneNumber – E.164 formatted phone number (e.g. '+31612345678')

✏️ Text & Numeric Types

For structured text, numbers, and identifiers:

  • Text – A valid text string (e.g. 'foo', 'Lorem ipsum dolor sit amet' or '')
  • Integer – Whole number (e.g. 42)
  • Float – Decimal number (e.g. 3.14)
  • Percentage – Decimal number between 0 and 1 (e.g. 0, 0.5 or 1)
  • Url – Valid absolute URL (e.g. 'https://example.com')
  • Uuid – RFC 4122 UUID string (e.g. '550e8400-e29b-41d4-a716-446655440000')

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-06-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固