“XMF Metagen 类”
XMF框架中的Metagen类提供了一个全面的工具包,用于生成和管理HTML元标签、开放图标签和其他SEO-related元数据。
Metagen类句柄:
- 标准HTML元标签(描述、关键字等)
- 用于社交共享的开放图元标签
- Twitter 卡元标签
- 结构化数据和JSON-LD
- 规范 URL
- 语言和区域设置规范
namespace Xmf;
class Metagen{ protected $meta = []; protected $ogTags = []; protected $twitterTags = []; protected $jsonLd = []; protected $canonicalUrl; protected $language;
public function __construct() {}
public function setDescription(string $description): self {}
public function setKeywords(string $keywords): self {}
public function renderAll(): string {}}use Xmf\Metagen;
$metagen = new Metagen();
// Set basic meta tags$metagen->setDescription('This is my awesome website');$metagen->setKeywords('php, xoops, web development');
// Render to HTMLecho $metagen->renderAll();
// Output:// <meta name="description" content="This is my awesome website" />// <meta name="keywords" content="php, xoops, web development" />打开图元标签
Section titled “打开图元标签”开放图谱标签有助于控制内容在社交媒体上共享时的显示方式。
基本开放图设置
Section titled “基本开放图设置”$metagen = new Metagen();
$metagen->setOpenGraphProperty('og:title', 'My Awesome Article');$metagen->setOpenGraphProperty('og:description', 'Learn how to use Metagen for SEO');$metagen->setOpenGraphProperty('og:image', 'https://example.com/image.jpg');$metagen->setOpenGraphProperty('og:url', 'https://example.com/article');$metagen->setOpenGraphProperty('og:type', 'article');
echo $metagen->renderAll();结构化数据和 JSON-LD
Section titled “结构化数据和 JSON-LD”JSON-LD提供搜索引擎可以更好理解的结构化数据。
文章结构化数据
Section titled “文章结构化数据”$metagen = new Metagen();
$articleData = [ '@context' => 'https://schema.org', '@type' => 'Article', 'headline' => 'Understanding XOOPS 4.0', 'description' => 'A comprehensive guide to XOOPS modernization', 'image' => 'https://example.com/article.jpg', 'datePublished' => '2026-01-31T10:00:00Z', 'dateModified' => '2026-01-31T15:00:00Z', 'author' => [ '@type' => 'Person', 'name' => 'John Developer', 'url' => 'https://example.com/author' ]];
$metagen->setJsonLd($articleData);
echo $metagen->renderAll();模区块集成示例
Section titled “模区块集成示例”Blog/Article 模区块
Section titled “Blog/Article 模区块”namespace MyModule\Controller;
use Xmf\Metagen;use MyModule\Repository\ArticleRepository;
class ArticleController{ public function viewAction($id) { $repository = new ArticleRepository(); $article = $repository->getById($id);
if (!$article) { return $this->notFound(); }
// Initialize Metagen $metagen = new Metagen();
// Set article metadata $metagen->setTitle($article->getTitle()); $metagen->setDescription( substr($article->getBody(), 0, 160) ); $metagen->setKeywords( implode(', ', $article->getTags()) ); $metagen->setAuthor($article->getAuthorName());
// Open Graph $metagen->setOpenGraphProperty('og:type', 'article'); $metagen->setOpenGraphProperty('og:title', $article->getTitle()); $metagen->setOpenGraphProperty('og:description', $article->getExcerpt()); $metagen->setOpenGraphProperty('og:image', $article->getFeaturedImage()); $metagen->setOpenGraphProperty('og:url', $article->getUrl());
// Canonical URL $metagen->setCanonicalUrl($article->getUrl());
// Store in template $this->template['metagen'] = $metagen;
return $this->render('article/view.php'); }}<!-- In your template header --><?php if (isset($metagen)): ?> <?php echo $metagen->renderAll(); ?><?php endif; ?>
<!-- Standard HTML structure --><!DOCTYPE html><html><head> <meta charset="utf-8"> <?php echo $metagen->renderAll(); ?> <title><?php echo $metagen->getTitle(); ?></title></head><body> <!-- Content --></body></html>SEO 优化
Section titled “SEO 优化”- 每页都有独特的描述(150-160 个字符)
- 相关关键词(每页5-10个主要关键词)
- 规范 URL 用于防止重复内容
- 开放图谱标签用于社交媒体优化
- 结构化数据用于增强搜索结果
- 移动视口用于响应式设计的元标记
完成SEO实施
Section titled “完成SEO实施”$metagen = new Metagen();
// Basic meta tags$metagen->setTitle('My Website - Web Development Services');$metagen->setDescription('Professional web development services');$metagen->setKeywords('web development, php, xoops');$metagen->setAuthor('John Developer');$metagen->setLanguage('en');
// Canonical URL$metagen->setCanonicalUrl('https://example.com/services/web-development');
// Open Graph for social sharing$metagen->setOpenGraphProperty('og:title', 'Web Development Services');$metagen->setOpenGraphProperty('og:description', 'Professional services');$metagen->setOpenGraphProperty('og:image', 'https://example.com/og-image.jpg');$metagen->setOpenGraphProperty('og:url', 'https://example.com/services/web-development');$metagen->setOpenGraphProperty('og:type', 'website');
// Twitter Card$metagen->setTwitterCard('summary_large_image');$metagen->setTwitterProperty('twitter:site', '@mycompany');$metagen->setTwitterProperty('twitter:title', 'Web Development Services');$metagen->setTwitterProperty('twitter:image', 'https://example.com/twitter-image.jpg');
echo $metagen->renderAll();API 参考
Section titled “API 参考”| 方法 | 参数 | 返回 | 描述 |
|---|---|---|---|
setTitle() | 字符串 | 自我 | 设置页面标题 |
setDescription() | 字符串 | 自我 | 设置元描述 |
setKeywords() | 字符串 | 自我 | 设置元关键字 |
setAuthor() | 字符串 | 自我 | 设置作者姓名 |
setCanonicalUrl() | 字符串 | 自我 | 设置规范URL |
setLanguage() | 字符串 | 自我 | 设置页面语言 |
setViewport() | 字符串 | 自我 | 设置视口设置 |
setOpenGraphProperty() | 字符串,字符串 | 自我 | 添加 OG 标签 |
setTwitterCard() | 字符串 | 自我 | 设置 Twitter 卡片类型 |
setJsonLd() | 数组 | 自我 | 设置结构化数据 |
renderAll() | - | 字符串 | 渲染所有元标记 |
- 数据库 - XMF 数据库参考
- JWT - JWT XMF 中的身份验证
- ../../03-Module-Development/Best-Practices/Frontend-Integration - 前端集成最佳实践
- 引入: XOOPS 2.5.8
- 最后更新: XOOPS 4.0
- 兼容性: PHP 7.4+