SlideShare a Scribd company logo
1 of 8
How to create right structure of the
index.php file in your template
Some practical pieces of advice
Today’s publication is devoted to the index.php file.
We will suggest how to organize its structure.
Index.php is a main file of your template. It contains of basic
HTML markup and some PHP code.
Here we will try to describe main things that you have to know
about how to do good foundation of your new template.
First of all you have to forbid direct access to this file:
// no direct access
defined( ‘_JEXEC’ ) or die( ‘Restricted access’ );
It is always good to set some variables before HTML code.
Define path to your template so you could use it further:
$tpath = $this->baseurl.’/templates/’.$this->template;
Init application object:
$app = JFactory::getApplication();
And get template parameters:
$params = $app->getParams();
Usually you want to include some CSS and JS files for your
template. To do this you have to initialise Document object and
call addStyleSheet and/or addScript methods:
$doc = JFactory::getDocument();
$doc->addStyleSheet($tpath .
‘your_css_folder/your_cool_styles.css’);
$doc->addScrypt($tpath . ‘your_js_folder/megascript.js’);
Next we have to insert common head for HTML files with
DOCTYPE definition:
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0
Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml” xml:lang=”<?php
echo $this->language; ?>” lang=”<?php echo $this->language; ?
>” >
After that we can include Joomla head content.
<head>
<jdoc:include type=”head” />
</head>
<jdoc:include />
Main structure makes possible for you to show modules,
component, messages etc. on pages of your template.
Inside <body> tags you can use <jdoc: include/> structure to
show modules, component, messages etc. on pages of your
template.
System messages:
<jdoc: include type=”message“/>

Modules, for example search module:
<jdoc:include type=”module” name=”search” />
Search in this case is a position in your template described in
templateDetails.xml file.
For modules you can also define “style” attribute.
<jdoc:include type=”module” name=”leftmenu” style=”xhtml”/>
Style may be one of these:








xhtml – each module as separate div element
table – modules will be shown as a table with one column
horz - modules will be also shown as a table but horizontally
each module in own cell
rounded – modules are shown in div elements with a border
and rounded corners
none – module content is shown without title and container
Good coding style is to hide markup of inserting modules:

<?php if($this->countModules(‘search’)) : ?>
<div id=”search”>
<jdoc:include type=”modules” name=”search” style=”xhtml” />
</div>
<?php endif; ?>
And of course don’t forget to include component output:
<jdoc:include type=”component” />

Source of the article

More Related Content

More from Tonytemplates

10 Ecommerce Web Design Trends of 2016
10 Ecommerce Web Design Trends of 201610 Ecommerce Web Design Trends of 2016
10 Ecommerce Web Design Trends of 2016Tonytemplates
 
15 Best Website Templates of 2015 from Developer
15 Best Website Templates of 2015 from Developer15 Best Website Templates of 2015 from Developer
15 Best Website Templates of 2015 from DeveloperTonytemplates
 
10 most attractive magento fashion themes from Internet
10 most attractive magento fashion themes from Internet10 most attractive magento fashion themes from Internet
10 most attractive magento fashion themes from InternetTonytemplates
 
10 most popular electrical website templates
10  most popular electrical website templates10  most popular electrical website templates
10 most popular electrical website templatesTonytemplates
 
3 quick steps to create your own theme in cs cart-4.0.3
3 quick steps to create your own theme in cs cart-4.0.33 quick steps to create your own theme in cs cart-4.0.3
3 quick steps to create your own theme in cs cart-4.0.3Tonytemplates
 
How to install computer repair joomla 3.1 website theme
How to install computer repair joomla 3.1 website themeHow to install computer repair joomla 3.1 website theme
How to install computer repair joomla 3.1 website themeTonytemplates
 

More from Tonytemplates (6)

10 Ecommerce Web Design Trends of 2016
10 Ecommerce Web Design Trends of 201610 Ecommerce Web Design Trends of 2016
10 Ecommerce Web Design Trends of 2016
 
15 Best Website Templates of 2015 from Developer
15 Best Website Templates of 2015 from Developer15 Best Website Templates of 2015 from Developer
15 Best Website Templates of 2015 from Developer
 
10 most attractive magento fashion themes from Internet
10 most attractive magento fashion themes from Internet10 most attractive magento fashion themes from Internet
10 most attractive magento fashion themes from Internet
 
10 most popular electrical website templates
10  most popular electrical website templates10  most popular electrical website templates
10 most popular electrical website templates
 
3 quick steps to create your own theme in cs cart-4.0.3
3 quick steps to create your own theme in cs cart-4.0.33 quick steps to create your own theme in cs cart-4.0.3
3 quick steps to create your own theme in cs cart-4.0.3
 
How to install computer repair joomla 3.1 website theme
How to install computer repair joomla 3.1 website themeHow to install computer repair joomla 3.1 website theme
How to install computer repair joomla 3.1 website theme
 

Recently uploaded

Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...
Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...
Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...anilsa9823
 
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...CIOWomenMagazine
 
Pokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy TheoryPokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy Theorydrae5
 
Independent Escorts in Lucknow (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...
Independent Escorts in Lucknow  (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...Independent Escorts in Lucknow  (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...
Independent Escorts in Lucknow (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...gurkirankumar98700
 
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdf
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdfBreath, Brain & Beyond_A Holistic Approach to Peak Performance.pdf
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdfJess Walker
 
Introducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfIntroducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfnoumannajam04
 
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceanilsa9823
 
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改atducpo
 
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girlsPooja Nehwal
 
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot And
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot AndCall Girls In Andheri East Call US Pooja📞 9892124323 Book Hot And
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot AndPooja Nehwal
 
LC_YouSaidYes_NewBelieverBookletDone.pdf
LC_YouSaidYes_NewBelieverBookletDone.pdfLC_YouSaidYes_NewBelieverBookletDone.pdf
LC_YouSaidYes_NewBelieverBookletDone.pdfpastor83
 
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceanilsa9823
 
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,dollysharma2066
 
Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666nishakur201
 
Lilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxLilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxABMWeaklings
 
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...Sanjna Singh
 
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceanilsa9823
 
The Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushThe Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushShivain97
 
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改atducpo
 

Recently uploaded (20)

Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...
Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...
Lucknow 💋 High Class Call Girls Lucknow 10k @ I'm VIP Independent Escorts Gir...
 
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...
Understanding Relationship Anarchy: A Guide to Liberating Love | CIO Women Ma...
 
Pokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy TheoryPokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy Theory
 
Independent Escorts in Lucknow (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...
Independent Escorts in Lucknow  (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...Independent Escorts in Lucknow  (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...
Independent Escorts in Lucknow (Adult Only) 👩🏽‍❤️‍💋‍👩🏼 8923113531 ♛ Escort S...
 
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdf
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdfBreath, Brain & Beyond_A Holistic Approach to Peak Performance.pdf
Breath, Brain & Beyond_A Holistic Approach to Peak Performance.pdf
 
Introducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfIntroducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdf
 
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
 
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改
文凭办理《原版美国USU学位证书》犹他州立大学毕业证制作成绩单修改
 
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
 
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot And
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot AndCall Girls In Andheri East Call US Pooja📞 9892124323 Book Hot And
Call Girls In Andheri East Call US Pooja📞 9892124323 Book Hot And
 
LC_YouSaidYes_NewBelieverBookletDone.pdf
LC_YouSaidYes_NewBelieverBookletDone.pdfLC_YouSaidYes_NewBelieverBookletDone.pdf
LC_YouSaidYes_NewBelieverBookletDone.pdf
 
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
 
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
 
Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666
 
escort service sasti (*~Call Girls in Paschim Vihar Metro❤️9953056974
escort service  sasti (*~Call Girls in Paschim Vihar Metro❤️9953056974escort service  sasti (*~Call Girls in Paschim Vihar Metro❤️9953056974
escort service sasti (*~Call Girls in Paschim Vihar Metro❤️9953056974
 
Lilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxLilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptx
 
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...
(KAVYA) Call Girls Humayun Nagar ✔️Just Call 7001035870✔️ HI-Fi Hyderabad Esc...
 
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
 
The Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushThe Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by Mindbrush
 
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改
办理国外毕业证学位证《原版美国montana文凭》蒙大拿州立大学毕业证制作成绩单修改
 

How to create right structure of the index.php file in your template

  • 1. How to create right structure of the index.php file in your template Some practical pieces of advice
  • 2. Today’s publication is devoted to the index.php file. We will suggest how to organize its structure.
  • 3. Index.php is a main file of your template. It contains of basic HTML markup and some PHP code. Here we will try to describe main things that you have to know about how to do good foundation of your new template. First of all you have to forbid direct access to this file: // no direct access defined( ‘_JEXEC’ ) or die( ‘Restricted access’ ); It is always good to set some variables before HTML code. Define path to your template so you could use it further: $tpath = $this->baseurl.’/templates/’.$this->template; Init application object: $app = JFactory::getApplication(); And get template parameters: $params = $app->getParams();
  • 4. Usually you want to include some CSS and JS files for your template. To do this you have to initialise Document object and call addStyleSheet and/or addScript methods: $doc = JFactory::getDocument(); $doc->addStyleSheet($tpath . ‘your_css_folder/your_cool_styles.css’); $doc->addScrypt($tpath . ‘your_js_folder/megascript.js’); Next we have to insert common head for HTML files with DOCTYPE definition: <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1transitional.dtd”> <html xmlns=”http://www.w3.org/1999/xhtml” xml:lang=”<?php echo $this->language; ?>” lang=”<?php echo $this->language; ? >” >
  • 5. After that we can include Joomla head content. <head> <jdoc:include type=”head” /> </head> <jdoc:include /> Main structure makes possible for you to show modules, component, messages etc. on pages of your template. Inside <body> tags you can use <jdoc: include/> structure to show modules, component, messages etc. on pages of your template.
  • 6. System messages: <jdoc: include type=”message“/> Modules, for example search module: <jdoc:include type=”module” name=”search” /> Search in this case is a position in your template described in templateDetails.xml file. For modules you can also define “style” attribute. <jdoc:include type=”module” name=”leftmenu” style=”xhtml”/>
  • 7. Style may be one of these:      xhtml – each module as separate div element table – modules will be shown as a table with one column horz - modules will be also shown as a table but horizontally each module in own cell rounded – modules are shown in div elements with a border and rounded corners none – module content is shown without title and container
  • 8. Good coding style is to hide markup of inserting modules: <?php if($this->countModules(‘search’)) : ?> <div id=”search”> <jdoc:include type=”modules” name=”search” style=”xhtml” /> </div> <?php endif; ?> And of course don’t forget to include component output: <jdoc:include type=”component” /> Source of the article

Editor's Notes

  1. This presentation was made on the base of the blog post - http://tonytemplates.com/blog/?p=364