สารบัญ

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
ไปที่หลังบ้านทำการติดตั้งคอมโพเน้นท์ก่อน จากนั้นไปที่คอมโพเน้นท์ของเราที่สร้างเอาไว้
แสดงข้อความกับเวลา
 

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
สอบถามรัน cron ด้วย url ใน extension เป็นลิงค์แบบไหนค่ะ [phpBB]
โดย eange08 จ 06 พ.ย. 2023 6:11 pm บอร์ด สอบถามปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
2
792
จ 13 พ.ย. 2023 12:53 pm โดย eange08 View Topic สอบถามรัน cron ด้วย url ใน extension เป็นลิงค์แบบไหนค่ะ [phpBB]
ใช้โมดูลแล้วขึ้น JUri not found
โดย Thanapoom1514 จ 06 พ.ย. 2023 3:52 pm บอร์ด Joomla Development
0
1679
จ 06 พ.ย. 2023 3:52 pm โดย Thanapoom1514 View Topic ใช้โมดูลแล้วขึ้น JUri not found
How to Add Animation and Transitions to React Components?
โดย Codalien จ 06 พ.ย. 2023 2:33 pm บอร์ด JavaScript & jQuery Ajax & Node.JS
0
6115
จ 06 พ.ย. 2023 2:33 pm โดย Codalien View Topic How to Add Animation and Transitions to React Components?
สอบถามเว็บแจ้ง error JApplicationSite::isClient()
โดย Thanapoom1514 จ 06 พ.ย. 2023 1:58 pm บอร์ด Joomla Development
2
672
พ 08 พ.ย. 2023 2:44 pm โดย mindphp View Topic สอบถามเว็บแจ้ง error JApplicationSite::isClient()
วิเคราะห์สาเหตุที่รถแบตเตอรี่มีไฟฟ้าแต่สตาร์ทไม่ติด
โดย GreatBattery จ 06 พ.ย. 2023 1:21 pm บอร์ด Share Knowledge
0
474
จ 06 พ.ย. 2023 1:21 pm โดย GreatBattery View Topic วิเคราะห์สาเหตุที่รถแบตเตอรี่มีไฟฟ้าแต่สตาร์ทไม่ติด
วิธีเปิด ssh ใน vmware exsi 5 ทำอย่างไร ssh open port vmware
โดย mindphp อ 05 พ.ย. 2023 5:07 pm บอร์ด Linux - Web Server
0
1207
อ 05 พ.ย. 2023 5:07 pm โดย mindphp View Topic วิธีเปิด ssh ใน vmware exsi 5 ทำอย่างไร ssh open port vmware
สเปกเซิร์ฟเวอร์สำหรับ Joomla เวอร์ชั่นต่างๆ ตั้งแต่ 1.5, 2.5, 3.x, 4.x, 5.x ไว้สำหรับเลือก Host ให้ตรงเวอร์ชั่นที่เราใช้
โดย mindphp ส 04 พ.ย. 2023 5:32 am บอร์ด Joomla Developing Knowledge
2
464
ส 04 พ.ย. 2023 11:54 am โดย mindphp View Topic สเปกเซิร์ฟเวอร์สำหรับ Joomla เวอร์ชั่นต่างๆ ตั้งแต่ 1.5, 2.5, 3.x, 4.x, 5.x ไว้สำหรับเลือก Host ให้ตรงเวอร์ชั่นที่เราใช้
สอบถามต้องการลบไฟล์ที่มาจาก URL ต้องทำอย่างไร
โดย eange08 ศ 03 พ.ย. 2023 4:33 pm บอร์ด Programming - PHP
5
912
ส 04 พ.ย. 2023 5:33 pm โดย eange08 View Topic สอบถามต้องการลบไฟล์ที่มาจาก URL ต้องทำอย่างไร