Bedingte Auszeichnung
Die (:if:)
Direktive erlaubt es, Teile einer Seite bei der Darstellung zu berücksichtigen oder auszuschließen.
Anwendung der (:if:)-Direktive
Der grundsätzliche Aufbau der (:if:)
Direktive ist
(:if Bedingung Parmeter:) body (:ifend:) (:if Bedingung Parmeter:) body (:else:) body (:ifend:) (:if Bedingung Parmeter:) body (:elseif Bedingung Parameter:) body (:ifend:) (:if Bedingung Parmeter:) body (:elseif Bedingung Parameter:) body (:else:) body (:ifend:) |
wobei "Bedingung" eine der unten genannten zu testenden Bedingungen bezeichnet und "Parameter" einen Wert oder ein anderes Argument der Bedingung beschreibt.
Beachten Sie, dass (:if:)
ohne Parameter und (:ifend:)
identisch sind. Beachten Sie auch, dass (:if Bedingung:)
automatisch eine vorhergehende Bedingung beendet. Wegen verschachtelter Bedingungen in mehreren Ebenen siehe verschachtelte Bedingungen.
Eingebaute Bedingungen
Die folgenden Bedingungen sind eingebaut:
(:if name SEITENNAME:)
- aktueller Seitenname ist "
SEITENNAME
" oder "GRUPPENNAME.SEITENNAME
" (:if group GRUPPENNAME:)
- aktueller Name der Gruppe ist "
GRUPPENNAME
" (:if auth LEVEL SEITENNAME:)
- Anwenderautorisierung - d. h. "seine Berechtigung" - entspricht einem "
LEVEL
" wobei derLEVEL
:read
,edit
,upload
,attr
oderadmin
sein kann;SEITENNAME
ist optional.
Das wird meistens benutzt, um Teile des Quelltextes, die nur für Verfasser oder Administratoren nützlich sind, für diese sichtbar zu machen und vor anderen zu verbergen.
Sicherheitswarnung: Um Inhalte zu sicher verstecken, ist weder diese noch eine andere bedingte Auszeichnung ausreichend. Bedingungte Auszeichnungen können in vielen Fällen einfach umgangen werden, wie in Passwörter beschrieben wird. Siehe auch Sicherheit, PITS:01417. Sie müssen zusätzlich die Seite schützen.
Der Grund ist, dass ein Benutzer, der eine Seite bearbeiten oder den Quellkode ansehen kann, auch den Inhalt innerhalb der bedingten Auszeichnung sehen kann. (:if auth @readers,@editors:)
- Der Aktuelle Besucher ist Mitglied mindestens einer der Gruppen "@readers" oder "@editors". Dies kann mit AuthUser oder durch eigene Rezepte konfiguriert werden (seit PmWiki 2.3.17).
(:if authid:)
- aktueller Anwender ist authentifiziert - d. h. er hat sich durch "Login" ausgewiesen - um diese Bedingung anwenden zu können, muss das Wiki die Benutzerautorisierung aktiviert haben oder ein anderes Rezept, das die
$AuthId
-Variable setzt. (:if enabled InvalidLogin:)
- Username und Passwort nicht authentifiziert. - um diese Bedingung anwenden zu können, muss das Wiki das Cookbook:AuthUser-Rezept eingeschlossen haben.
(:if true:)
- den folgenden Text immer auswerten/anzeigen, true klein schreiben(!) ,Groß/Kleinschreibung wird unterschieden
(:if false:)
- den folgenden Text nicht auswerten/anzeigen (gleicht einem Kommentar, aber Seiten-Text-Variablen werden gesetzt!), false klein schreiben(!), Groß/Kleinschreibung wird unterschieden
(:if attachments FILENAMES PAGENAME:)
PAGENAME
hat einen Anhang oder mehrere Anhänge unter den angegebenen.PAGENAME
kann weggelassen werden, dann wird die aktuelle Seite untersucht.FILENAMES
bezeichnen einen Anhang wie "bild1.jpg" oder Anhangsmuster, getrennt durch Kommata, wie "bild*.jpg,*.png", wobei der Stern für eine beliebige Anzahl weiterer Zeichen steht. Fehlt der Parameter, zählt jeglicher Anhang (d. h. "*").
Wenn die Bedingung in einer Sidebar, einem Header oder einem Footer benutzt wird und derSeitenname
ist nicht angegeben, wird die Bedingung auf die Hauptseite angewendet.
Beispiel:(:if attachments *.png,*.gif Groupname.PageName:)
Beachten Sie: Keine Anführungszeichen um die Dateinamen.
In den folgenden "if date"-Beispielen gilt:
DATE
kann Jahr-Monat sein. Jahr-Monat-Tag ist optional.VALUE
kann ein Datum sein, muss aber mit strtotime() erkannt werden.DATE
(oderDATE1
undDATE2
unten) haben ein etwas strengeres Format, das keine Leerzeichen enthalten darf. Jedes Leerzeichen inDATE1
oderDATE2
verursacht unvorhersagbare Ergebnisse.- "now" oder "today" wird angenommen, wenn (
VALUE
) weggelassen wird - Daten stehen im Standardformat
yyyy-mm-dd
oderyyyymmdd
oderyyyymmddThhmm
(Beachten Sie das "T" zwischen dem Datum und der Uhrzeit, und sehen Sie sich die Anmerkung oben zuVALUE
an) - das ".." darf keine führenden (zusammen mit
DATE1
) oder folgenden Leerzeichen (zusammen mitDATE2
) haben.
(:if date DATE VALUE:)
- wahr, wenn
VALUE
im Bereich vonDATE
liegt. (:if date DATE1.. VALUE:)
- wahr, wenn
VALUE
(oder das aktuelle Datum, wennVALUE
fehlt) gleichDATE1
oder später ist (unbegrenzt) (:if date ..DATE2 VALUE:)
- wahr, wenn
VALUE
(oder das aktuelle Datum, wennVALUE
fehlt) gleichDATE2
oder früher ist (unbegrenzt) (:if date DATE1..DATE2 VALUE:)
- wahr, wenn
VALUE
(oder das aktuelle Datum, wennVALUE
fehlt) zwischenDATE1
undDATE2
(inklusive) liegt (:if enabled VAR:)
- wahr, wenn PHP
VAR
existiert und nicht falsch ist (:if enabled AuthPw:)
- wahr, wenn der Anwender irgend ein Passwort während der aktuellen Browser-Sitzung eingegeben hat.
- Das bedeutet nicht, dass der Anwender das korrekte Passwort eingegeben hat, nur dass er eines eingegeben hat.
(:if equal STRING1 STRING2:)
- wahr, wenn
STRING1
=STRING2
; benutzen Sie Anführungszeichen, wenn die Zeichenkette oder Zeichenkettenvariable Leerzeichen enthält, z. B."MY STRING"
(:if match REG_EXPRESSION:)
- wahr, wenn der aktuelle Seitenname dem regulären Ausdruck entspricht
(:if exists PAGENAME:)
- wahr, wenn die Seite "
pagename
" oder "groupname.pagename
" existiert (Groß/Kleinschreibung wird nicht unterschieden)
Mehrere Seiten können angegeben werden, z. B.(:if exists p1,p2,meineGruppe.*:)
ist wahr, wenn wenigstens eine unter den Seiten "p1" oder "p2" oder unter jenen in der "meineGruppe"-Gruppe existiert. (:if ontrail WikiTrailPage ThisPage:)
- wahr, wenn
ThisPage
in einer Liste ist, die als trail auf der Seite "WikiTrailPage
" benutzt wird
Die "name"- und "group"-Bedingungen arbeiten sogar in einer inkludierten Seite, da "name" und "group" immer die aktuell ausgegebene Seite überprüfen, und nicht die Seite, in der die Auszeichnung enthalten ist (Quelltext).
Beachten Sie: Es gibt keine eingebaute Bedingung, die ?action= testet. Um zu prüfen, ob die aktuell angeforderte Aktion gleich ACTION ist, benutze (:if equal {$Action} ACTION:)
.
Verknüpfte Bedingungen
In einigen Fällen, wo eingebaute Bedingungen einen Parameter haben, können die Parameter mit Hilfe eines Kommas aufgezählt werden, siehe
-
(:if name Name1,Name2,-Name3:)
-
(:if group -Group1,Group2,Group3:)
Negierte Bedingungen
Negierte Formen der Bedingungen funktionieren ebenfalls:
(:if !attachments:)
- diese Seite hat keine Anhänge
(:if ! name PAGENAME:)
(:if name -PAGENAME :)
- aktuelle Seite heißt NICHT "
PAGENAME
" (:if group -GROUPNAME1,-GROUPNAME2 :)
- diese Gruppe heißt weder "
GROUPNAME1
" noch "GROUPNAME2
"
Verschachtelte Bedingungen
Beachten Sie, dass jedes (:if cond:)
automatisch das vorhergehende beendet, daher können Auszeichnungen einfach durchgeprüft werden (und sind nicht verschachtelt).
(:if enabled AuthPw:)
| * Du hast ein Passwort eingegeben |
(:if auth read:)
| * Du darfst lesen |
(:if auth read Group.Page:)
| * Du darfst die Group.Page lesen |
(:if auth edit:)
| * Du darfst bearbeiten |
(:if auth upload:)
| * Du darfst Dateien hochladen |
(:ifend:)
|
Die folgenden beiden Beispiele sind identisch in ihrer Wirkung:
(:if cond1:)
cond1 ist waht(:if cond2:)
cond2 ist wahr(:ifend:)
(:if cond1:)
cond1 ist wahr(:ifend:)
(:if cond2:)
cond2 ist wahr(:ifend:)
Bedingungen können seit der Version 2.2.beta66 verschachtelt werden. Für verschachtelte Bedingung müssen Sie die if und die korrespondierenden else/ifend nummerieren.
(:if cond1:) cond1 ist wahr (:if2 cond2:) cond1 und cond2 sind wahr (:else2:) cond1 ist wahr, cond2 ist falsch (:if2end:) (:else:) cond1 ist falsch, Test auf cond2 wurde ignoriert (:ifend:) |
Für eine bessere Lesbarkeit wurden Einrückungen vorgenommen.
Nutzung von Platzhaltern (Wildcard)
Das Zeichen *
kann als Platzhalter (Wildcard/Joker) genutzt werden, um jedes beliebige Zeichen keinmal, einmal oder mehrfach zu repräsentieren.
Das Zeichen ?
kann als Platzhalter (Wildcard/Joker) genutzt werden, um ein beliebiges Zeichen exakt einmal zu repräsentieren.
Die Platzhalterzeichen (*
und ?
) können auch mit den name- und group-Bedingungen benutzt werden:
(:if name PmCal.2005* :)
- aktuelle Seite gehört in die Gruppe PmCal und beginnt mit 2005
(:if group PmWiki* :)
- aktuelle Seite gehört in die Gruppe PmWiki oder in eine Gruppe, die mit PmWiki beginnt
(:if name Profiles.*,-Profiles.Profiles :)
- aktuelle Seite gehört in die Gruppe
Profiles
, ist aber nichtProfiles.Profiles
Anwendung mit PageList-Vorlagen
Die bedingte Auszeichnung ((:if :)
-Direktive) wird intensiv mit PageList-Vorlagen genutzt.
Anwendung mit Seiten Variablen:
Bedingungen zur Strukturierung von pagelist Ausgaben:
(:if equal {<$Group}:)
Am Anfang der Liste(:if equal {>$Group}:)
Am Ende der Liste(:if ! equal {=$Group} {<$Group}:)
Erstes Element der Gruppe(:if ! equal {=$Group} {>$Group}:)
Letztes Element der Gruppe
Gebrauch von Seiten-Text-Variablen, Seitenspezifische Variablen und Formatierungsanweisungen im Ausdruck
Seiten-Text-Variablen (STVs), seitenspezifischen Variablen (SVs) und Markup-Expressions können in Bedingungen verwendet werden. Sie werden zugewiesen und ausgewertet, bevor die Bedingungen ausgewertet werden.
Kombinieren von Bedingungen
Bedingungen (wie vorher definiert) können zu komplexeren bedingten Ausdrücken kombiniert werden, in dem eine der drei folgenden untereinander äquivalenten Formen benutzt werden:
(:if expr EXPRESSION :) (:if [ EXPRESSION ] :) (:if ( EXPRESSION ) :)@] |
Bedingungen werden mit Booleschen Operatoren und Klammern zu Ausdrücken verbunden. In der folgenden Tabelle sind A und B entweder reguläre Bedingungen oder geklammerte sub-Ausdrücke regulärer Bedingungen:
Expression | Operator | Result |
---|---|---|
A and B | And | WAHR, wenn sowohl A als auch B WAHR sind. |
A or B | Or | WAHR, wenn entweder A oder B WAHR ist oder beide WAHR sind. |
A xor B | Xor | WAHR, wenn entweder A oder B WAHR ist, aber nicht beide. |
! A | Not | WAHR, wenn A nicht WAHR ist. |
A && B | And | WAHR, wenn sowohl A als auch B WAHR sind. |
A || B | Or | WAHR, wenn A oder B WAHR ist oder beide WAHR sind. |
Beispiel
(:if [ name SomePage and group SomeGroup ]:) entspricht (:if name SomeGroup.SomePage:) |
Wichtige Hinweise:
- Leerzeichen um Operatoren und Klammern sind erforderlich.
- Bei unpaariger Klammersetzung gibt es keine spezifischen Fehlerhinweise.
- Bei verschachtelten Ausdrücken werden runde Klammer (keine eckigen) benutzt.
Das Folgende ist folglich ein möglicher Weg, eine Bedingung zu formulieren, durch die der folgende Inhalt nur angezeigt wird, wenn der Nutzer entweder Administrator ist oder wenn er eingeloggt ist und das angegebene Datum abgelaufen ist.
(:if [ auth admin || ( authid && date 2006-06-01 ) ] :)
Das Verschachteln mit Hilfe eckiger Klammern funktioniert wie erwartet nicht:
(:if [ auth admin || [ authid && date 2006-06-01 ] ] :)
Hinweis: Dies funktioniert nicht!
Ein häufiger Anwendungsfall für komlexere Tests sind Ausdrücke wie
(:if expr auth admin || auth attr || auth edit :) [[Logout -> {$Name}?action=logout]] (:ifend:) |
wodurch ein Logout-Link genau dann angezeigt wird, wenn admin-, attr- oder edit-Rechte vorhanden sind.
Administratoren (Fortgeschrittene)
Neue Bedingungen kreieren
Siehe das Kochbuch-Rezept Cookbook:ConditionalMarkupSamples (nur auf Englisch verfügbar).
Siehe auch spezielle Verweise für die Benutzung von {*$Variablen}
.
Übersetzung von PmWiki.ConditionalMarkup, Originalseite auf PmWikiDe.ConditionalMarkup — Backlinks
Zuletzt geändert: | PmWikiDe.ConditionalMarkup | am 18.12.2022 |
PmWiki.ConditionalMarkup | am 17.12.2022 |