Računalništvo, telefonija
09.07.2015 12:54

Deli z drugimi:

Share

Kratke kode (shortcode) v WordPressu

Kratke kode v WordPressu nam lahko kot administratorjem oz. urednikom prihranijo kar nekaj časa, saj nam omogočajo, da s kratkim ukazom vstavimo večji kos (oblikovane) vsebine.
Kratke kode (shortcode) v WordPressu
Kratke kode (shortcode) v WordPressu

Po objavah vodičev po optimizaciji spletnih strani tokrat nadaljujemo s prispevkom znotraj rubrike izdelava spletnih strani.

Kratke kode v WordPressu nam lahko kot administratorjem oz. urednikom prihranijo kar nekaj časa, saj nam omogočajo, da s kratkim ukazom vstavimo večji kos (oblikovane) vsebine. Dodaten plus je tudi ta, da lahko funkcijo za izpis kratke kode v prihodnosti popravimo, s tem pa se bo popravil tudi izpis na vseh straneh ali objavah, kjer smo kodo uporabili. Zaradi tega je uporaba kratkih kod nadvse primerna za izpis vsebin, ki jih hočemo prikazati pri vsaki objavi (kontaktni podatki, gumbi za deljenje na družbenih omrežjih, klic k akciji ipd.).

WordPress že v privzeti namestitvi vsebuje nekaj predpripravljenih kratkih kod, njihova prava moč pa se pokaže, ko začnemo razvijati lastne.

Primer kratke kode iz WordPress Codexa.

Izdelava nove kratke kode

Novo kratko kodo napišemo v datoteko functions.php naše izbrane teme (nahaja se v mapi wp-content/themes/). Če želimo kratke kode ločiti od ostale funkcionalnosti teme, lahko izdelamo tudi novo PHP datoteko npr. shortcodes.php in nato le to vključimo vfunctions.php z ukazom:

require_once(‘shortcodes.php’);

Kratko kodo lahko uporabljamo na dva načina:

brez parametrov (metodo bomo uporabljali takrat, ko je vsebina, ki jo izpisujemo vedno enaka – statična),

Primer: [mojakoda]

s parametri (izpisujemo podobno vsebino, ki pa je glede na uporabljeni parameter drugačna. V spodnjem primeru, so izpisani različni obrazci glede na vrednost parametra id.)


Primer: [spletniobrazec id=1]


Kratka koda brez parametrov

Najprej pripravimo funkcijo, ki se bo izvedla, ko bomo kratko kodo uporabili. Za primer bomo pripravili kratko kodo, ki nam bo na koncu vsake objave izpisala kontakne podatke avtorja.

function kontaktni_podatki() { return ‘mag. Janez Novak
vodja PR službe
Data d.o.o.
Dunajska 136
1000 Ljubljana’; }

Paziti moramo, da uporabimo ukaz “return” in ne katerega od ukazov za izpis v PHP-ju kot sta “echo” ali “print_r”, ker v tem primeru vsebina ne bo izpisana na mestu, kjer smo kratko kodo uporabili ampak drugje (po navadi na vrhu vsebine strani, ni pa nujno) ali pa sploh ne.

Da bomo kratko kodo lahko uporabili v WordPressu, jo moramo še registrirati.

add_shortcode(‘kontakt’, ‘kontaktni_podatki’);

S tem ukazom imamo zdaj na voljo kratko kodo – [kontakt], ki jo lahko poljubno uporabimo na straneh ali v objavah.

Kratka koda s parametri

Razširimo zgornjo kodo tako, da lahko spreminjamo kontaktno osebo in njeno funkcijo v podjetju.

function napredni_kontaktni_podatki($atts) {

extract(shortcode_atts(array(

‘ime’ => ‘mag. Janez Novak’,

‘funkcija’ => ‘vodja PR službe’

), $atts));

return ” . $ime . ‘
‘ . $funkcija . ‘
Data d.o.o.
Dunajska cesta

136
1000 Ljubljana’;

}

Za izluščenje parametrov smo uporabili PHP funkcijo extract v povezavi z v WordPress vgrajeno funkcijo shortcode_atts. Imena parametrov si lahko poljubno izberemo, ravno tako število, brez težav npr. dodamo še parameter naslov.

Kodo še registrirajmo z ukazom:

add_shortcode(‘naprednikontakt’, ‘napredni_kontaktni_podatki’);

Zdaj lahko kratko kodo uporabimo v prispevkih:

[naprednikontakt ime=”dr. Testko testek” funkcija=”vodja svetovalcev”]

V primeru, da uporabnik kratko kodo uporabi brez parametrov [naprednikontakt], bodo uporabljene privzete vrednosti, ki smo jih definirali. V našem primeru je to “mag. Janez Novak” za ime in “vodja PR službe2 za njegovo funkcijo. Privzeta vrednost je lahko tudi prazna npr.


‘ime’ => ”,

‘funkcija’ => ”


Kratka koda z zaključkom

V primeru, da želimo nek del besedila oblikovati na bolj kompleksen način (npr. pripravljamo nek gumb za klic k akciji), lahko pripravimo tudi “kratko kodo z zaključkom” (enclosing shortcode).

function cta_gumb($atts, $content = null) {

extract(shortcode_atts(array(

‘link’ => ‘#’

), $atts));

return ‘‘ . $content .

”;

}

add_shortcode(‘ctabox’, ‘cta_gumb’);

Kratko kodo pa potem uporabimo takole:

[ctabox link=”http://data.si”]Nujno preberi članek![/ctabox]

Za konec še opozorilo, da na ta način pripravljene kodo ne bodo delovale, če jih boste uporabili v katerem od gradnikov (widget). Če potrebujete tudi to funkcionalnost, morate v datotekofunctions.php dodati ukaz (morda ga datoteka že vsebuje od prej):

add_filter(‘widget_text’, ‘do_shortcode’);


V predstavljenih primerih smo uporabili izjemno preproste kratke kode oz. funkcije, seveda pa bi bile lahko, glede na potrebe, tudi dosti bolj kompleksne npr. izpis zadnjih objav ali komentarja, prikaz naključnega oglasa itd. Možnosti je veliko, vsekakor pa nam bodo kratke kodo prihranile kar nekaj časa pri pripravljanju novih strani ali objav.

Vam je bil prispevek všeč in bi radi prebrali več vodičev po WordPressu? Pripravili smo vam:

Pripravil: Borut Ratej


Prijavi napako v članku

Povezave

Članek je pripravljen v sodelovanju s partnerjem DATA d.o.o.
Za več informacij so vam na voljo pri DATA d.o.o.
Ob kontaktu povejte, da ste objavo zasledili v Računalniških novicah.

Želite biti obveščeni o novostih, ki jih pripravljamo s partnerjem DATA d.o.o.? Vpišite svoj e-mail in se prijavite na BREZPLAČNE e-novice, od katerih se lahko kadarkoli odjavite.




Kaj berejo drugi?

Partnerji Računalniških novic Prikaži vse

REMIS d.o.o.

Letališka cesta 32, 1000 Ljubljana, Tel: 01 521 13 18
Zlati partner

BROTHER CEE GmbH

Glavna cesta 46, 4202 Naklo, Tel: 030 600 474
Dejavni so v 28 državah, Brotherjevi izdelki pa so na voljo v več kot 100 državah.  Od ustanovitve korporacije leta 1934 si prizadevajo, da bi ideje prenesli v prakso z ustvarjanjem ... Več
Zlati partner

NLB d. d.

Trg republike 2, 1000 Ljubljana, Tel: 01 477 2000
Dobro delujoč finančni sistem je temelj sodobnega gospodarstva in banke pri tem opravljajo pomembno družbeno funkcijo. Banke morajo biti zmožne posojati denar potrošnikom in podjetjem ... Več
Zlati partner

TEHNOLOŠKI PARK LJUBLJANA d.o.o.

Tehnološki park 19, 1000 Ljubljana, Tel: 01 620 34 01
Tehnološki park Ljubljana (TP LJ) kot mednarodni tehnološki hub, kjer se stikajo vrhunske tehnologije, srečujejo najboljša razvojna podjetja in nastajajo nove tehnološke zgodbe. ... Več