Difference between revisions of "How do you put a module inside an article?"

From Joomla! Documentation

(Marked this version for translation)
(34 intermediate revisions by 19 users not shown)
Line 1: Line 1:
You can insert a module inside an article using the "{loadposition xx}" command, as follows:
+
<noinclude><languages /></noinclude>
#Use the menu manager to create a new unique menu name.  This will be used in the module manager to assign the mainmenu module you instantiate.  Its name will appear in the basic parameters menu name list. --[[User:Dpminusa|Dpminusa]] 10:34, 1 March 2009 (UTC)
+
<noinclude>{{Joomla version|version=2.5|time=and after|comment=<translate><!--T:1-->
#Create a module and set its position to any value that doesn't conflict an existing template position. You can type in the position value instead of selecting it from the drop-down list. For example, use the position "myposition".
+
series</translate>}}</noinclude>
#Assign the module to the Menu Items that contain the articles that you want the module to show in. You can also just assign the module to "All" Menu Items.
+
<translate>
#Edit the articles where you want this module to show and insert the text "{loadposition myposition}" in the article, at the place where you want the module to show.
+
<!--T:2-->
The module will show at that point in the article.  
+
You will usually want to associate modules with articles in some way. The modules are allocated to module positions and the module positions appear somewhere on the Web page as determined by the template.  However, it is sometimes useful to have a module actually embedded within the article. Joomla core provides two ways to do that: loadposition and loadmodule.
 +
</translate>
  
[[Category:FAQ]]
+
<translate><!--T:3-->
[[Category:Version 1.5 FAQ]]
+
Syntax:</translate>
[[Category:Administration FAQ]]
+
*{loadposition position[, style]}
 +
*{loadmodule module[, title[, style]]}
 +
 
 +
<translate>
 +
===loadpostion=== <!--T:4-->
 +
To insert a module inside an article, you publish the module to a position and load that position in the article as follows:
 +
</translate>
 +
 
 +
<translate>
 +
<!--T:5-->
 +
#Create a module and set its position to '''''myposition'''''. '''''myposition''''' can be any value that doesn't conflict with an existing template position. Type in the position '''''myposition''''' and press enter instead of selecting it from the drop-down list.
 +
</translate>
 +
<translate>
 +
<!--T:6-->
 +
#Assign the module to '''All''' the Menu Items. This will make sure that it always appears, no matter how the visitor got to the article. The module will not show unless you put the command to load the module in an [[S:MyLanguage/article|article]].
 +
#Edit the articles where you want this module to appear and insert the text '''''{loadposition myposition}''''' in the article at the place where you want the module.
 +
</translate>
 +
 
 +
{{dablink|<translate><!--T:7-->
 +
*Note that this only works when the [[S:MyLanguage/Help25:Extensions_Plugin_Manager_Edit#Content_-_Load_Modules|''Content - Load Module'' plugin is enabled]]. If this plugin is disabled, the text ''{loadposition myposition}'' shows unchanged in the article.
 +
 
 +
<!--T:8-->
 +
Also, the name of the position should be all lowercase.  CamelCapitalization will fail.</translate>}}
 +
 
 +
 
 +
<translate>
 +
===loadmodule=== <!--T:9-->
 +
An alternative to "{loadposition xx}" is the "{loadmodule yyy}" variation which is handled by the same plugin.
 +
</translate>
 +
 
 +
<translate>
 +
<!--T:10-->
 +
In this case the plugin looks for the first module who's '''type''' matches the string 'yyy'. So, you could load a "mod_login" module by placing {loadmodule login} in your text. If you wish to load a specific instance of a module, because you have more than one login module e.g. titled as login1, login2, etc. you have to use {loadmodule login,login2} for the module titled as login2. You can also add the a style that is used for rendering the module, to do so add the style as third parameter like {loadmodule login,login2,xhtml}. If you don't add a style then "none" is used.
 +
</translate>
 +
 
 +
<translate>===Modules within Modules=== <!--T:11--></translate>
 +
<translate>
 +
<!--T:12-->
 +
It is possible in Joomla! 2.5+ and Joomla! 3.x+ to include a module within a "Custom HTML" module as they are processed by content plugins in the same way as articles.
 +
</translate>
 +
 
 +
<translate>
 +
<!--T:13-->
 +
To make this work, the option '''Prepare content''' must be enabled as shown in this screenshot.
 +
</translate>
 +
 
 +
[[File:j3x_custom_html_prepare_content_option-<translate><!--T:14-->
 +
en</translate>.png||<translate><!--T:15-->
 +
Showing the Prepare Content option in a Custom HTML module.</translate>]]
 +
 
 +
<translate>
 +
<!--T:16-->
 +
You should remember when doing this that you may experience formatting issues as the "chrome" of the "Custom HTML" module will surround the "chrome" of the included module potential having undesirable effects of the formatting or layout.
 +
</translate>
 +
 
 +
<noinclude>
 +
<translate>
 +
<!--T:17-->
 +
[[Category:Content Management FAQ]]
 +
[[Category:Article Management FAQ]]
 +
</translate>
 +
</noinclude>

Revision as of 19:44, 16 May 2015

Other languages:
Deutsch • ‎English • ‎Nederlands • ‎español • ‎français • ‎português do Brasil • ‎中文(台灣)‎
Joomla! 
≥ 2.5
series

You will usually want to associate modules with articles in some way. The modules are allocated to module positions and the module positions appear somewhere on the Web page as determined by the template. However, it is sometimes useful to have a module actually embedded within the article. Joomla core provides two ways to do that: loadposition and loadmodule.

Syntax:

  • {loadposition position[, style]}
  • {loadmodule module[, title[, style]]}

loadpostion[edit]

To insert a module inside an article, you publish the module to a position and load that position in the article as follows:

  1. Create a module and set its position to myposition. myposition can be any value that doesn't conflict with an existing template position. Type in the position myposition and press enter instead of selecting it from the drop-down list.
  2. Assign the module to All the Menu Items. This will make sure that it always appears, no matter how the visitor got to the article. The module will not show unless you put the command to load the module in an article.
  3. Edit the articles where you want this module to appear and insert the text {loadposition myposition} in the article at the place where you want the module.


loadmodule[edit]

An alternative to "{loadposition xx}" is the "{loadmodule yyy}" variation which is handled by the same plugin.

In this case the plugin looks for the first module who's type matches the string 'yyy'. So, you could load a "mod_login" module by placing {loadmodule login} in your text. If you wish to load a specific instance of a module, because you have more than one login module e.g. titled as login1, login2, etc. you have to use {loadmodule login,login2} for the module titled as login2. You can also add the a style that is used for rendering the module, to do so add the style as third parameter like {loadmodule login,login2,xhtml}. If you don't add a style then "none" is used.

Modules within Modules[edit]

It is possible in Joomla! 2.5+ and Joomla! 3.x+ to include a module within a "Custom HTML" module as they are processed by content plugins in the same way as articles.

To make this work, the option Prepare content must be enabled as shown in this screenshot.

Showing the Prepare Content option in a Custom HTML module.

You should remember when doing this that you may experience formatting issues as the "chrome" of the "Custom HTML" module will surround the "chrome" of the included module potential having undesirable effects of the formatting or layout.