สารบัญ

Front End และ Back End ใน Joomla Component

การสร้างคอมโพเน้นท์ของจูมล่านั้นจะมีการแบ่งออกเป็นสองส่วนคือ Front End (สำหรับผู้ใช้งานทั่วไป) และ Back End (สำหรับผู้ดูแลระบบ) ซึ่งในบทความนี้จะพูดถึงเฉพาะ Front End และ Back End สำหรับหลักการเขียน Component ของ Joomla ดูได้ที่บทความ สร้าง Componentเรียนรู้ MVC แบบ Joomla แบบง่ายซึ่งมีส่วนของ admin และ site ตามที่ได้กล่างข้างตน ซึ่งในการทำ Component เราจะเริ่มลำดับด้วย Back End หรือหลังบ้าน และตามด้วย Front End หรือหน้าบ้านของ joomla 

Back End

1. อันดับแรกให้ไปสร้างโฟลเดอร์คอมโพเน้นท์ com_frontbackend จากนั้นเพิ่มไฟล์ xml คือเป็นบอกรายละเอียดของ Component เช่น ชื่อของผู้พัฒนา, วันที่พัฒนา และยังบอกเกี่ยวกับไฟล์กับโฟลเดอร์ที่ใช้ใน Component อีกด้วย

ไฟล์ xml บอกรายละเอียดของ component และไฟล์กับโฟลเดอร์อื่น ๆ
สร้างไฟล์ xml เพื่อบอกรายละเอียดของ component

โค้ดในไฟล์ com_frontbackend.xml

<?xml version="1.0" encoding="utf-8"?>
<extension type="component" version="3.1" method="upgrade">
	<name>com_frontbackend</name>
	<author>Joomla! Project</author>
	<creationDate>February 2023</creationDate>
	<copyright>(C) 2006 Open Source Matters, Inc.</copyright>
	<license>GNU General Public License version 2 or later; see LICENSE.txt</license>
	<authorEmail>[email protected]</authorEmail>
	<authorUrl>www.joomla.org</authorUrl>
	<version>1.0.0</version>
	<description>COM_FRONTBACKEND_XML_DESCRIPTION</description>

<!-- โครงสร้างฝั่งหน้าเว็บ -->
	<files folder="site">
		<filename>controller.php</filename>
		<filename>router.php</filename>
		<filename>frontbackend.php</filename>
		<folder>controllers</folder>
		<folder>language</folder>
		<folder>models</folder>
		<folder>views</folder>
	</files>

<!-- โครงสร้างฝั่ง admin -->
	<administration>
		<menu>com_frontbackend</menu>
		<files folder="admin">
			<filename>controller.php</filename>
			<filename>frontbackend.php</filename>
			<filename>config.xml</filename>
			<folder>controllers</folder>
			<folder>helpers</folder>
			<folder>models</folder>
			<folder>views</folder>
		</files>
	</administration>
</extension>

 

2. สร้างไฟล์เริ่มแรกของคอมโพเน้นท์ com_frontbackend/frontbackend.php

ไปโฟลเดอร์ administrator กับไปที่ components จากนั้นก็ไปสร้าง com_frontbackend และไฟล์ php
สร้างโฟลเดอร์ com_frontbackend และไฟล์ php

Code ของไฟล์ frontbackend.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;
JHtml::_('behavior.tabstate');

if (!JFactory::getUser()->authorise('core.manage', 'com_frontbackend'))
{
	throw new JAccessExceptionNotallowed(JText::_('JERROR_ALERTNOAUTHOR'), 403);
}

JLoader::register('FrontbackendHelper', __DIR__ . '/helpers/frontbackend.php');

$controller = JControllerLegacy::getInstance('Frontbackend');
$controller->execute(JFactory::getApplication()->input->get('task'));
$controller->redirect();

 

3. Model จะเป็นในส่วนเกี่ยวกับฐานข้อมูล

3.1 สร้างโฟลเดอร์ models

3.2 สร้างไฟล์ models/test.php

ไปสร้างโฟลเดอร์ Models และไฟล์ test.php ซึ่งใน model จะเป็นส่วนที่เกี่ยว Database
สร้างโฟลเดอร์ Models และไฟล์ test.php

Code ของไฟล์ models/test.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;

class FrontBackendModelFrontBackend extends Joomla\CMS\MVC\Model\ListModel
{
    public function getItem()
    {
        $time = time();
        $date = date('d/m/Y', $time);
        return $date;
    }

}

 

4. Controller เป็นส่วนการจัดการส่วน view กับ model

4.1 สร้าง Default Controller โดยตั้งชื่อไฟล์เป็น controller.php

สร้างไฟล์ controller.php
สร้างไฟล์ controller.php

Code ของไฟล์ controller.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;

class FrontbackendController extends Joomla\CMS\MVC\Controller\BaseController
{
    
}

 

4.2 สร้างโฟลเดอร์ controllers

4.3 สร้างไฟล์ controllers/test.php

สร้างโฟลเดอร์ controllers และไฟล์ test.php จะเป็นส่วนการจัดการส่วน view กับ model
สร้างโฟลเดอร์ controllers และไฟล์ test.php

 

Code ของไฟล์ controllers/test.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;

class FrontbackendControllerTest extends Joomla\CMS\MVC\Controller\AdminController
{
    public function getModel($name = 'Test', $prefix = '', $config = array())
    {
        return parent::getModel($name, $prefix, $config);
    }
}

 

บรรทัดที่ 8-9 : เป็นการกำหนดให้ใช้ View (a) และ Layout (default)

5. View เป็นส่วนแสดงหน้าเว็บ

5.1 สร้างโฟลเดอร์ views เพื่อเก็บ View ทั้งหมดที่เราใช้งาน

5.1 สร้างโฟลเดอร์ views/frontbackend

5.2 สร้างไฟล์ views/frontbackend/view.html.php

 

ไปสร้างโฟลเดอร์ views และโฟลเดอร์ frontbackendจากนั้นสร้างไฟล์ view.html.php
ไปสร้างโฟลเดอร์ views และโฟลเดอร์ frontbackendจากนั้นสร้างไฟล์ view.html.php

 

Code ของไฟล์ views/frontbackend/view.html.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;

class FrontbackendViewFrontbackend extends Joomla\CMS\MVC\View\HtmlView
{
    public function display($tpl = null)
    {
        $this->item = $this->get('Item');
        
        FrontbackendHelper::addSubmenu('test');
        $this->sidebar = JHtmlSidebar::render();
        $this->addToolbar();
        parent::display($tpl);
    }

    public function addToolbar()
    {
        \Joomla\CMS\Toolbar\ToolbarHelper::title(JText::_('COM_FRONTBACKEND_CONTROL_PANEL'));
        \Joomla\CMS\Toolbar\ToolbarHelper::preferences('com_frontbackend');

    }
}

  

5.3 สร้างโฟลเดอร์ tmpl ในโฟลเดอร์

5.4 สร้างไฟล์ views/frontbackend/tmpl/default.php

ไปสร้างโฟลเดอร์ tmpl และไฟล์  default.php เป็นส่วงของการแสดงผลเช่นกัน แต่จะแสดงในส่วน admin
สร้างโฟลเดอร์ tmpl และไฟล์ default.php 

Code ของไฟล์ views/frontbackend/tmpl/default.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

defined('_JEXEC') or die;
?>

<h1>Hi! Back End</h1>
<p>Date : <?php echo $this->item;?></p>

 

6. helpers คือมีหน้าที่รับผิดชอบเฉพาะและชุดของฟังก์ชันที่เกี่ยวข้องซึ่งสามารถนำไปใช้ในส่วนต่าง ๆ ของส่วนขยายได้

สร้างโฟลเดอร์ helpers แล้วสร้างไฟล์ frontbackend.php

ไปสร้างโฟลเดอร์ helpers และข้างในก็มีไฟล์ php
สร้างโฟลเดอร์ helpers

โค้ดใน helpers/frontbackend.php

<?php
/**
 * @package     Joomla.Administrator
 * @subpackage  com_frontbackend
 *
 * @copyright   (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

 defined('_JEXEC') or die;

 class FrontbackendHelper
 {
    public static function addSubmenu($vName)
	{
		JHtmlSidebar::addEntry(
			JText::_('COM_FRONBACKEND_TEST'),
			'index.php?option=com_frontbackend&view=test',
			$vName == 'test'
		);

	}
 }

ทดสอบคอมโพเน้นท์โดยไปติดตั้งคอมโพเน้นท์ที่ส่วนเสริม

ไปที่ส่วนเสริมไปทำการติดตั้งตัวคอมโพเน้นท์
ติดตั้งคอมโพเน้นท์

 

แล้วลอง copy path URL ใส่ช่องค้นหา 

index.php?option=com_frontbackend&controller=a

ตัวอย่าง

http://localhost/Joomla_3_10/administrator/index.php?option=com_frontbackend&controller=test
ไปที่หลังบ้านทำการติดตั้งคอมโพเน้นท์ก่อน จากนั้นไปที่คอมโพเน้นท์ของเราที่สร้างเอาไว้
แสดงข้อความกับเวลา
 

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
แจ้งปัญหาโพสบทความลงในเว็บบอร์ดส่วนตัวไม่ได้
โดย internTk21 ศ 19 เม.ย. 2024 11:56 am บอร์ด MindPHP News & Feedback
1
5
ศ 19 เม.ย. 2024 12:15 pm โดย internTk21 View Topic แจ้งปัญหาโพสบทความลงในเว็บบอร์ดส่วนตัวไม่ได้
สอบถาม Google Structure ที่เหมาะกับคอร์สเรียนควรใช้แบบไหนดีค่ะ
โดย eange08 ศ 19 เม.ย. 2024 9:56 am บอร์ด Programming - PHP
1
10
ศ 19 เม.ย. 2024 10:28 am โดย mindphp View Topic สอบถาม Google Structure ที่เหมาะกับคอร์สเรียนควรใช้แบบไหนดีค่ะ
คำสั่งรวมไฟล์ และ บีบอัดในคำสั่งเดียว tar, zip
โดย mindphp พ 17 เม.ย. 2024 7:42 pm บอร์ด Linux - Web Server
0
41
พ 17 เม.ย. 2024 7:42 pm โดย mindphp View Topic คำสั่งรวมไฟล์ และ บีบอัดในคำสั่งเดียว  tar, zip
เช็คขนาดพื้นที่ฐานข้อมูล แต่ละก้อน แต่ละฐานข้อมูลว่าใช้พื้นที่ไปเท่าไหร่ ด้วย Comamnd Line
โดย mindphp จ 15 เม.ย. 2024 11:10 pm บอร์ด PostgreSQL
1
163
จ 15 เม.ย. 2024 11:14 pm โดย mindphp View Topic เช็คขนาดพื้นที่ฐานข้อมูล แต่ละก้อน แต่ละฐานข้อมูลว่าใช้พื้นที่ไปเท่าไหร่ ด้วย Comamnd Line
การติดตั้ง WSL เพื่อใช้งาน Linux Terminal บน Windows
โดย tsukasaz ศ 12 เม.ย. 2024 2:25 pm บอร์ด Share Knowledge
0
185
ศ 12 เม.ย. 2024 2:25 pm โดย tsukasaz View Topic การติดตั้ง WSL เพื่อใช้งาน Linux Terminal บน Windows
Super Сasual Dating - Real Women
โดย heroxbay ศ 12 เม.ย. 2024 8:55 am บอร์ด Microsoft Office Knowledge & line & Etc
0
140
ศ 12 เม.ย. 2024 8:55 am โดย heroxbay View Topic Super Сasual Dating - Real Women
Unsurpassed Сasual Dating - True Females
โดย pongsu1968 ศ 12 เม.ย. 2024 5:47 am บอร์ด Microsoft Office Knowledge & line & Etc
0
160
ศ 12 เม.ย. 2024 5:47 am โดย pongsu1968 View Topic Unsurpassed Сasual Dating - True Females
Question Tag ใช้อย่างไรในภาษาอังกฤษ
โดย internTk21 พฤ 11 เม.ย. 2024 10:46 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
83
พฤ 11 เม.ย. 2024 10:46 pm โดย internTk21 View Topic Question Tag ใช้อย่างไรในภาษาอังกฤษ