XMF Metagen-klasse
De klasse Metagen in het XMF Framework biedt een uitgebreide toolkit voor het genereren en beheren van HTML-metatags, Open Graph-tags en andere SEO-gerelateerde metagegevens.
Klassenoverzicht
Section titled “Klassenoverzicht”De klasse Metagen verwerkt:
- Standaard HTML-metatags (beschrijving, trefwoorden, enz.)
- Open Graph-metatags voor sociaal delen
- Twitter Card-metatags
- Gestructureerde gegevens en JSON-LD
- Canonieke URL’s
- Taal- en landspecificaties
Basisklassestructuur
Section titled “Basisklassestructuur”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 {}}Basisgebruik
Section titled “Basisgebruik”Eenvoudige metatags
Section titled “Eenvoudige metatags”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" />Open Graph-metatags
Section titled “Open Graph-metatags”Open Graph-tags helpen bepalen hoe inhoud wordt weergegeven wanneer deze op sociale media wordt gedeeld.
Basis Open Graph-instellingen
Section titled “Basis Open Graph-instellingen”$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();Gestructureerde gegevens en JSON-LD
Section titled “Gestructureerde gegevens en JSON-LD”JSON-LD biedt gestructureerde gegevens die zoekmachines beter kunnen begrijpen.
Artikel gestructureerde gegevens
Section titled “Artikel gestructureerde gegevens”$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();Voorbeelden van module-integratie
Section titled “Voorbeelden van module-integratie”Blog/artikelmodule
Section titled “Blog/artikelmodule”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'); }}Sjabloonintegratie
Section titled “Sjabloonintegratie”Sjabloonimplementatie
Section titled “Sjabloonimplementatie”<!-- 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>Beste praktijken
Section titled “Beste praktijken”SEO Optimalisatie
Section titled “SEO Optimalisatie”- Unieke beschrijvingen voor elke pagina (150-160 tekens)
- Relevante zoekwoorden (5-10 primaire zoekwoorden per pagina)
- Canonieke URL’s om dubbele inhoud te voorkomen
- Open Graph-tags voor optimalisatie van sociale media
- Gestructureerde gegevens voor verbeterde zoekresultaten
- Mobile viewport-metatag voor responsief ontwerp
Volledige SEO-implementatie
Section titled “Volledige SEO-implementatie”$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-referentie
Section titled “API-referentie”Kernmethoden
Section titled “Kernmethoden”| Werkwijze | Parameters | Retouren | Beschrijving |
|---|---|---|---|
setTitle() | tekenreeks | zelf | Paginatitel instellen |
setDescription() | tekenreeks | zelf | Metabeschrijving instellen |
setKeywords() | tekenreeks | zelf | Meta-trefwoorden instellen |
setAuthor() | tekenreeks | zelf | Auteursnaam instellen |
setCanonicalUrl() | tekenreeks | zelf | Stel canonieke URL |
setLanguage() | tekenreeks | zelf | Paginataal instellen |
setViewport() | tekenreeks | zelf | Viewport-instellingen instellen |
setOpenGraphProperty() | tekenreeks, tekenreeks | zelf | OG-tag toevoegen |
setTwitterCard() | tekenreeks | zelf | Twitter-kaarttype instellen |
setJsonLd() | array | zelf | Gestructureerde gegevens instellen |
renderAll() | - | tekenreeks | Geef alle metatags weer |
Gerelateerde documentatie
Section titled “Gerelateerde documentatie”- Database - XMF databasereferentie
- JWT - JWT-authenticatie in XMF
- ../../03-Module-Development/Best-Practices/Frontend-Integration - Best practices voor frontend-integratie
Bronnen
Section titled “Bronnen”- Open Graph-protocol
- Twitterkaartdocumentatie
- Gestructureerde gegevens van Schema.org
- Google Zoeken Centraal
Versie-informatie
Section titled “Versie-informatie”- Geïntroduceerd: XOOPS 2.5.8
- Laatst bijgewerkt: XOOPS 4.0
- Compatibiliteit: PHP 7.4+