承接 zjkiza/truncate-html 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

zjkiza/truncate-html

最新稳定版本:v0.6.1

Composer 安装命令:

composer require zjkiza/truncate-html

包简介

A flexible HTML truncation service that safely truncates HTML content without breaking the tag structure. Enable different ways of measuring length by bytes or by characters.

README 文档

README

A flexible PHP service to safely truncate HTML content without breaking tag structure. Provides multiple truncation strategies—by bytes or by characters—making it ideal for displaying safe previews, snippets or social meta content.

Flexible PHP service for safely shortening HTML content without breaking tag structure. It supports different truncation strategies: byte-wise or character-wise.

Features

  • ✔️ Preserves valid HTML – no broken or unclosed tags
  • ✔️ Supports truncating by bytes (for precise control, ex. for database or API)
  • ✔️ Supports truncating by characters (multibyte safe)
  • ✔️ Custom void tags
  • ✔️ Simple API, PSR-4 autoload compatible
  • ✔️ PHP 8.1+, mbstring required

Installation

Install via Composer:

composer require zjkiza/truncate-html

You need PHP 8.1+ and ext-mbstring enabled.

Basic Usage

Truncate HTML to a byte or character limit, safely:

use ZJKiza\TruncateHtml\TruncateHtml;
use ZJKiza\TruncateHtml\Enum\Strategy;

$html = '<div><p>Some rich <b>HTML</b> ...</p></div>';

$truncate = new TruncateHtml();

// --- Byte limit (precise control, for APIs/db):
$resultByte = $truncate->execute($html, Strategy::Bytes, 100);

// --- Character limit (supports multibyte chars!):
$resultChar = $truncate->execute($html, Strategy::Characters, 80);

After truncation, the string remains a valid HTML fragment.

Output Examples

For byte/char limits, HTML tags remain valid:

  • Input:
    <div><p>Lorem <b>ipsum</b> ...</p></div>
  • Truncated output (limit adjusted):
    <div><p>Lorem <b>ipsum</b> ...</p></div>
  • Even if the cut is inside a tag, all tags are properly closed!

Truncation Strategies

  • Strategy::Bytes: Cuts by bytes. Use when you need strict byte limits (DB, APIs, etc).
  • Strategy::Characters: Cuts by characters using mbstring (multi-byte safe, e.g., for Unicode strings).

Default encoding is UTF-8, but can be overridden.

Usage in Frameworks / (example: Laravel, Symfony)

Register TruncateHtml as a service for injection.

Symfony (services.yaml)

services:
  ZJKiza\TruncateHtml\Contract\TruncateHtmlInterface:
      class: ZJKiza\TruncateHtml\TruncateHtml

Then simply inject as needed in your services/controllers.

Laravel (in AppServiceProvider)

use ZJKiza\TruncateHtml\Contract\TruncateHtmlInterface;
use ZJKiza\TruncateHtml\TruncateHtml;

public function register()
{
        $this->app->bind(TruncateHtmlInterface::class, function () {
            return TruncateHtml::create();
}

And type-hint TruncateHtmlInterface in your controllers/services.

Advanced: Custom void/self-closing tags

If you need to support additional self-closing/void tags, pass them as an array when constructing:

$truncate = new TruncateHtml(['customtag', ... ]);

Testing

To run tests:

composer install
vendor/bin/phpunit

License

MIT License (c) 2025 Zoran Jankovic

Author & Contact

  • Zoran Jankovic

Contributions

Pull requests and suggestions are welcome! See tests/Functionality/TruncateHtmlTest.php for examples.

Changelog

See CHANGELOG.md

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-17