krzar/laravel-dom
最新稳定版本:v1.0.0
Composer 安装命令:
composer require krzar/laravel-dom
包简介
Modern tool for Laravel to read and manipulate DOM Documents in Laravel style.
README 文档
README
Package allows you to query, create, update and delete DOM Documents in Laravel style
using functions like where, orWhere, whereHas etc.
You can get the first queried Element/Node or Collection of Elements/Nodes.
Requirements
- Laravel 12+
- PHP 8.2+ (with ext-dom)
Installation
composer require krzar/laravel-dom
Documentation
Look here for every class detailed documentation, also to see how to add and manipulate DOM elements: Documentation
Examples
Create new Document
use KrZar\LaravelDom\Document; $htmlDocument = Document::loadHtml($html); $xmlDocument = Document::loadXml($xml);
Basic query example
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', 'searched-class'); })->get();
Available selectors
equals (default)
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', '=', 'searched-class'); })->get(); // OR $elements = $document->query('div', function(Query $query) { $query->whereEquals('class', 'searched-class'); })->get();
contains
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', 'contains', 'searched-class'); })->get(); // OR $elements = $document->query('div', function(Query $query) { $query->whereContains('class', 'searched-class'); })->get();
not equals
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', '!=', 'searched-class'); })->get(); // OR $elements = $document->query('div', function(Query $query) { $query->whereNotEquals('class', 'searched-class'); })->get();
not contains
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', '!contains', 'searched-class'); })->get(); // OR $elements = $document->query('div', function(Query $query) { $query->whereNotContains('class', 'searched-class'); })->get();
has
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->whereHas('id'); })->get();
You can also use where('id', 'has')
not has
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->whereNotHas('id'); })->get();
You can also use where('id', '!has')
Advanced examples
orWhere
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', 'contains', 'searched-class') ->orWhereHas('id'); })->query('a', function(Query $query) { $query->whereHas('href') ->whereContains('class', 'link'); })->get();
deep search
By default, a query is not searching deep inside DOM; it looks only for first children (XPath /).
To search deep for any child (XPath //) you need to add true on the end of query.
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('a', function(Query $query) { $query->where('class', 'searched-class'); }, true)->get();
You can also use queryDeep method.
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->queryDeep('a', function(Query $query) { $query->where('class', 'searched-class'); })->get();
Look for any
You can also look for any element just using *
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('*', function(Query $query) { $query->where('class', 'searched-class'); })->get();
Nested conditions
If you want to search for condition like a || (b && c). You can make it using subqueries.
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('span', function(Query $query) { $query->whereContains('class', 'searched-class') ->orWhere(function (Query $subQuery) { $subQuery->whereNotContains('class', 'another-class') ->whereEquals('title', 'some-title'); }); })->get();
Query text content
You can also query text content of an element.
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', 'contains', 'searched-class') ->whereText('Some text'); } )->get();
Available text methods
whereTextwhereTextEqualswhereTextNotEqualswhereTextContainswhereTextNotContainsorWhereTextorWhereTextEqualsorWhereTextNotEqualsorWhereTextContainsorWhereTextNotContains
By default these methods search only for text content of an element, not for element children.
To search deep for any child (XPath //) you need to add true on the end of the method.
For example:
use KrZar\LaravelDom\Document; use KrZar\LaravelDom\Query\Query; $document = Document::loadHtml($html); $elements = $document->query('div', function(Query $query) { $query->where('class', 'contains', 'searched-class') ->whereTextContains('Some text', true); } )->get();
统计信息
- 总下载量: 8
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-08-24