There are some crucial differences between Joomla modules and components which you need to understand

Article Audience: Joomla Webmasters

Unless you understand the difference between a module and a component, you will find it very difficult to administer your Joomla installation. This article will explain the difference between modules and components and give examples of the usage of each of them.


Modules are usually small pieces of functionality designed to present information in your site. They can appear a number of times, on a number of pages in various positions.

On the contrary components are a full blown application, usually quite complex and are to the main body if a page.

Also each module can be viewed in various pages, and the position of each module can be easily changed. You are allowed to select the menu items where a module is displayed. 

A good example of the usage of this functionality is targeted advertising.

If your site has various sections, you can create module for each section. Each module will contain a targeted advert for the section. Now instead of showing all the modules, all the time, you customise the visibility of the module such that each advert is displayed only in the relevant menu links.

Below you can see a screenshot of how to choose the menu items where a module is displayed. The module is displayed in the chosen menu items only.

Joomla Selected Menu Items

Typical examples of standard Joomla modules are the following. As we can see the function of each of the modules mentioned is quite restricted.

  • Main / User / Top and other menus
  • Latest News
  • Popular Articles
  • Polls
  • Login Form
  • Syndication Details
  • etc...

3rd Party Modules include

Installed modules can be found in the Modules > Site Modules menu, or Installers > Modules. Configuration of modules is typically very easy, and is done by clicking on the module in Site Modules page.

Let's help you manage your Joomla better


Free Joomla tips ebook button


On the other hand, a Joomla component is typically more complex, with extensive functionality and capabilities. A component can only be displayed in the main area of a page, and can only be displayed in a single page (usually). Links to components are usually done by creating menu items as shown in the image below.

Components usually have a particular page or pages for their configuration.

Create Component Menu Link

Standard Joomla Components

  • FrontPage component - this is used to display the contents in the frontpage. One can decide how many items to show in the frontpage, in how many columns, how many articles to have an intro only or not and various other options. To place a content item in the frontpage, the frontpage option must be checked on.
  • WebLinks - this is a component where the user can configure different link categories and add items to each category.
  • Banners - allows a Joomla website to create and display banners for advertising purposes

Recommend Reading: Joomla Extensions to take your website to the next level

3rd Party Components

Modules vs Components

   Modules   Components 
Complexity  Low  Usually medium to high
Visibility  Various   Single Page
Position   Various   Main Body only
Configuration   Low  Extensive


The Joomla Extensions site lists an extensive number of free and commercial templates. There are also reviews and voting mechanisms to help you decide exactly what extensions are best for your needs. Also the extensions section of this site, describes a number of extensions which we have found to be very useful.

Warning: 3rd party extension may compromise your site's security. Always make sure that your code comes from a trusted source.

One more thing... Did you know that people who share useful stuff like this post look AWESOME too? ;-)
Please leave a useful comment with your thoughts, then share this on your Facebook group(s) who would find this useful and let's reap the benefits together. Thank you for sharing and being nice!

Featured On

Inc Magazine Logo  

Sitepoint logo  

CSS Tricks logo   

webdesignerdepot logo   WPMU DEV logo   

and many more!


Get Started Now With ShutterstockShutterstock

Best Rated Caching Plugin

Make your website faster 

Monstrous B-Day Party

CLICK HERE for discounts!

Monstrous bday party

How to make your website FAST!

Step-by-step - free email course, how to make your website load in less than 1 second 


The Outstanding HungryJPEG Bundles

AWESOMENESS! Bundles of premium font + graphic packs at more than 96% OFF!  Get a bundle for just $9 - ONLY!

The Hungry JPEG Awesome font bundles


Work with

CollectiveRay (formerly known as DART Creations) is interested in developing partnerships with mutual benefit. If you like the stuff we publish and would like to develop a relationship, we'd be happy to hear from you. Go on - drop us a line - we'd love to hear from you :-)


Disclosure: CollectiveRay is funded personally out of pure passion for helping people working with websites. We do however generate some income through recommendations of products. This means if you click on a link and purchase an item we link to, we will receive a small sum out of that sale. We usually partner with vendors to make your purchase cheaper than buying direct.


InMotion Hosting CollectiveRay Deal

who are we?

CollectiveRay is run by David Attard - working in and around the web design niche for more than 12 years, we provide actionable tips for people who work with and on websites. We also run - a website for drone hobbyists.

David attard

Follow us on Social

Follow us on Facebook   Subscribe to our RSS Feed   Follow us on Twitter


Where are we hosted?

This site is proudly powered by FAST VPS InMotion Servers and given an insane speed thanks to StackPath CDN!

Web Hosting stackpath


Popular Content

Joomla extensions to take your website to the NEXT level

Is your Joomla website reaching its full potential? We install many of these extensions on almost ALL of our Joomla sites - why don't you check them out our list of Joomla Extensions and see whether you can take your site to the next level?