定制 quadcompanies/metadata 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

quadcompanies/metadata

最新稳定版本:1.1

Composer 安装命令:

composer require quadcompanies/metadata

包简介

A unified Metadata, SEO, and Social Media library for Laravel.

README 文档

README

A unified Metadata, SEO, and Social Media library for Laravel. Define your page information once and render it everywhere: HTML Meta tags, Open Graph, Twitter Cards, and Schema.org JSON-LD.

Features

  • Fluent API: Easily set metadata in your controllers.
  • Eloquent Integration: Use the HasMetadata trait to map model attributes to SEO fields automatically.
  • Blade Directive: Simple @metadata directive to render everything in your <head>.
  • Schema.org: Helpers for generating standard JSON-LD scripts.
  • Sitemaps: Generate sitemap.xml via Artisan command.

Installation

composer require quadcompanies/metadata

Usage

1. Define Once (Controller)

use QuadCompanies\Metadata\Facades\Metadata;

public function show(Product $product)
{
    Metadata::title($product->name)
        ->description($product->excerpt)
        ->image($product->featured_image_url)
        ->url(url()->current())
        ->siteName('My Awesome Store')
        ->twitterCard('summary_large_image');

    return view('products.show', compact('product'));
}

2. Render Everywhere (Blade)

Add the directive to your layout's <head>:

<!DOCTYPE html>
<html>
<head>
    @metadata
</head>
...

3. Eloquent Integration

Add the HasMetadata trait to your models:

use QuadCompanies\Metadata\Traits\HasMetadata;

class Post extends Model
{
    use HasMetadata;

    public function metadataMapping(): array
    {
        return [
            'title' => 'title',
            'description' => 'excerpt',
            'image' => fn($model) => $model->getFirstMediaUrl('images'),
        ];
    }
}

Then in your controller:

public function show(Post $post)
{
    $post->applyMetadata();
    return view('posts.show');
}

4. Schema.org JSON-LD

use QuadCompanies\Metadata\Schema\SchemaBuilder;

Metadata::addSchema(SchemaBuilder::article([
    'headline' => 'Awesome Article',
    'author' => ['@type' => 'Person', 'name' => 'John Doe'],
]));

5. Sitemaps

To generate a sitemap:

php artisan metadata:sitemap

Standards

This package follows PSR-12 coding standards and is designed to be data-agnostic (no migrations required).

License

The MIT License (MIT). Please see License File for more information.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-28

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固