<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.stephanschlegel.de/index.php?action=history&amp;feed=atom&amp;title=ProcessWire_-_One_Page_Website</id>
	<title>ProcessWire - One Page Website - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.stephanschlegel.de/index.php?action=history&amp;feed=atom&amp;title=ProcessWire_-_One_Page_Website"/>
	<link rel="alternate" type="text/html" href="https://wiki.stephanschlegel.de/index.php?title=ProcessWire_-_One_Page_Website&amp;action=history"/>
	<updated>2026-05-06T17:59:15Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikizone</subtitle>
	<generator>MediaWiki 1.35.14</generator>
	<entry>
		<id>https://wiki.stephanschlegel.de/index.php?title=ProcessWire_-_One_Page_Website&amp;diff=24689&amp;oldid=prev</id>
		<title>84.155.186.41: /* Beispiel für Repeater Matrix */</title>
		<link rel="alternate" type="text/html" href="https://wiki.stephanschlegel.de/index.php?title=ProcessWire_-_One_Page_Website&amp;diff=24689&amp;oldid=prev"/>
		<updated>2020-07-20T10:14:28Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Beispiel für Repeater Matrix&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left diff-editfont-monospace&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;de&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Nächstältere Version&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Version vom 20. Juli 2020, 10:14 Uhr&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l16&quot; &gt;Zeile 16:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 16:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Wir nutzen ein Feld &amp;#039;&amp;#039;nav_title&amp;#039;&amp;#039; für jedes Repeater Matrix Item. Ist dieses ausgefüllt erstellen wir einen Navigationspunkt.&lt;/div&gt;&lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Wir nutzen ein Feld &amp;#039;&amp;#039;nav_title&amp;#039;&amp;#039; für jedes Repeater Matrix Item. Ist dieses ausgefüllt erstellen wir einen Navigationspunkt.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Als ID / Name für jede Section nutzen wir einfach die ID des RepeaterMatrix Items mit dem Buchstaben p als Prefix.&lt;/div&gt;&lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Als ID / Name für jede Section nutzen wir einfach die ID des RepeaterMatrix Items mit dem Buchstaben p als Prefix.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt; &lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt;+&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt; &lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt;+&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;Die Navi in dieser Form erstellt für die aktive Seite ein Untermenü, das alle Sections (mit nav_title) enthält. Die Submenüs der anderen (nicht aktiven) Seiten erstellen wir hier nicht. &lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;nav_hashNav.php&amp;#039;&amp;#039;&amp;#039;&lt;/div&gt;&lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;nav_hashNav.php&amp;#039;&amp;#039;&amp;#039;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;syntaxhighlight lang=&amp;quot;php&amp;quot;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class=&#039;diff-marker&#039;&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;syntaxhighlight lang=&amp;quot;php&amp;quot;&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>84.155.186.41</name></author>
	</entry>
	<entry>
		<id>https://wiki.stephanschlegel.de/index.php?title=ProcessWire_-_One_Page_Website&amp;diff=24688&amp;oldid=prev</id>
		<title>84.155.186.41: Die Seite wurde neu angelegt: „== Links ==    https://processwire.com/talk/topic/7297-one-page-websites/  == Strategien ==  * Kindseiten um Sections zu erstellen * Repatermatrix o.ä. könne…“</title>
		<link rel="alternate" type="text/html" href="https://wiki.stephanschlegel.de/index.php?title=ProcessWire_-_One_Page_Website&amp;diff=24688&amp;oldid=prev"/>
		<updated>2020-07-20T10:12:59Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „== Links ==    https://processwire.com/talk/topic/7297-one-page-websites/  == Strategien ==  * Kindseiten um Sections zu erstellen * Repatermatrix o.ä. könne…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Links ==&lt;br /&gt;
 &lt;br /&gt;
 https://processwire.com/talk/topic/7297-one-page-websites/&lt;br /&gt;
&lt;br /&gt;
== Strategien ==&lt;br /&gt;
&lt;br /&gt;
* Kindseiten um Sections zu erstellen&lt;br /&gt;
* Repatermatrix o.ä. können zu Sections werden&lt;br /&gt;
&lt;br /&gt;
== Navigation erstellen ==&lt;br /&gt;
* Smooth Scroll nutzen (sieht einfach besser aus und hilft bei der Orientierung.&lt;br /&gt;
* Klasse in CSS Editor wenn nicht alle Links Smooth Scroll Links werden sollen&lt;br /&gt;
* Klasse in Navigation&lt;br /&gt;
&lt;br /&gt;
=== Beispiel für Repeater Matrix ===&lt;br /&gt;
Wir nutzen ein Feld &amp;#039;&amp;#039;nav_title&amp;#039;&amp;#039; für jedes Repeater Matrix Item. Ist dieses ausgefüllt erstellen wir einen Navigationspunkt.&lt;br /&gt;
Als ID / Name für jede Section nutzen wir einfach die ID des RepeaterMatrix Items mit dem Buchstaben p als Prefix.&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;nav_hashNav.php&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;php&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;?php namespace ProcessWire;&lt;br /&gt;
$mainMenuMarkup = &amp;#039;&amp;#039;;&lt;br /&gt;
$activeClass=&amp;#039;&amp;#039;;&lt;br /&gt;
$homePage = $pages-&amp;gt;get(&amp;quot;/&amp;quot;);&lt;br /&gt;
$navItems = $homePage-&amp;gt;and($homePage-&amp;gt;children(&amp;#039;menu.id=1&amp;#039;));&lt;br /&gt;
$mainMenuMarkup .= &amp;#039;&amp;lt;ul class=&amp;quot;nav&amp;quot;&amp;gt;&amp;#039;;&lt;br /&gt;
foreach ($navItems as $navItem){&lt;br /&gt;
    $itemMarkup=&amp;#039;&amp;#039;;&lt;br /&gt;
    $hashNav=&amp;#039;&amp;#039;;&lt;br /&gt;
    // Current Page ?&lt;br /&gt;
    if($navItem-&amp;gt;id == $page-&amp;gt;id){&lt;br /&gt;
        $activeClass = ($navItem-&amp;gt;id == $page-&amp;gt;id) ? &amp;quot; active&amp;quot; : &amp;quot;&amp;quot;;&lt;br /&gt;
        $hashNavItems = getHashNavItems($navItem);&lt;br /&gt;
        $hashNav = renderHashNav($hashNavItems);&lt;br /&gt;
    }&lt;br /&gt;
    $itemMarkup = &amp;#039;&lt;br /&gt;
    &amp;lt;li class=&amp;quot;nav-item&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;a class=&amp;quot;nav-link &amp;#039;.$activeClass.&amp;#039;&amp;quot; href=&amp;quot;&amp;#039;.$navItem-&amp;gt;url.&amp;#039;&amp;quot;&amp;gt; &amp;#039;. $navItem-&amp;gt;title.&amp;#039;&amp;lt;/a&amp;gt;&lt;br /&gt;
        &amp;#039;.$hashNav.&amp;#039;&lt;br /&gt;
    &amp;lt;/li&amp;gt;&lt;br /&gt;
    &amp;#039;;&lt;br /&gt;
    $mainMenuMarkup .= $itemMarkup;&lt;br /&gt;
} &lt;br /&gt;
$mainMenuMarkup .= &amp;#039;&amp;lt;/ul&amp;gt;&amp;#039;;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
// HASH NAVI FUNCTIONS&lt;br /&gt;
// If Hash-Links on actual page use them as subnav&lt;br /&gt;
// Hashes are created when field nav_title in layout_blocks is filled&lt;br /&gt;
// caching (i.e proCache) is recommended&lt;br /&gt;
&lt;br /&gt;
function getHashNavItems($p){&lt;br /&gt;
	$navItems = array(); // pid=&amp;gt;title &lt;br /&gt;
	foreach($p-&amp;gt;layout_blocks as $lb){&lt;br /&gt;
		if($navTitle = $lb-&amp;gt;nav_title) $navItems[] = array(&amp;#039;pid&amp;#039;=&amp;gt;$lb-&amp;gt;id, &amp;#039;title&amp;#039; =&amp;gt; $lb-&amp;gt;nav_title);&lt;br /&gt;
	}&lt;br /&gt;
	if( !empty($navItems) ){&lt;br /&gt;
		return $navItems;&lt;br /&gt;
	}else return false;&lt;br /&gt;
}&lt;br /&gt;
function renderHashNav($subnavItems){&lt;br /&gt;
	$out=&amp;#039;&amp;#039;;&lt;br /&gt;
	if(!empty($subnavItems)){&lt;br /&gt;
		$out .= &amp;#039;&amp;lt;ul class=&amp;quot;nav nav-v npl nml&amp;quot;&amp;gt;&amp;#039;;&lt;br /&gt;
		foreach($subnavItems as $item){&lt;br /&gt;
			$out .= &amp;#039;&amp;lt;li&amp;gt;&amp;lt;a class=&amp;quot;scroll&amp;quot; href=&amp;quot;#p&amp;#039;.$item[&amp;#039;pid&amp;#039;].&amp;#039;&amp;quot;&amp;gt;&amp;#039;.$item[&amp;#039;title&amp;#039;].&amp;#039;&amp;lt;/a&amp;gt;&amp;lt;/li&amp;gt;&amp;#039;;&lt;br /&gt;
		}&lt;br /&gt;
		$out .= &amp;#039;&amp;lt;/ul&amp;gt;&amp;#039;;&lt;br /&gt;
	}&lt;br /&gt;
	return $out;&lt;br /&gt;
}&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;SmoothScroll JS&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;javascript&amp;quot;&amp;gt;&lt;br /&gt;
$(document).on(&amp;#039;click&amp;#039;, &amp;#039;a.scroll&amp;#039;, function (event) {&lt;br /&gt;
		event.preventDefault();&lt;br /&gt;
		$(&amp;#039;html, body&amp;#039;).animate({&lt;br /&gt;
			scrollTop: $($.attr(this, &amp;#039;href&amp;#039;)).offset().top&lt;br /&gt;
		}, 100);&lt;br /&gt;
	});&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Smooth Scroll wird mittlerweile auch von vielen Browsern direkt unterstützt. Mit der scroll-behaviour Eigenschaft kann man es aktivieren.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;SmoothScroll (CSS)&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;css&amp;quot;&amp;gt;&lt;br /&gt;
html,body{&lt;br /&gt;
    min-height: 100%;&lt;br /&gt;
    height: 100%;&lt;br /&gt;
}&lt;br /&gt;
html{&lt;br /&gt;
	scroll-behavior: smooth;&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>84.155.186.41</name></author>
	</entry>
</feed>