สารบัญ

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

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
การเป็น Software Tester ที่ดีเป็นแบบไหน
โดย BXP พ 28 ก.พ. 2024 5:03 pm บอร์ด Software testing
0
525
พ 28 ก.พ. 2024 5:03 pm โดย BXP View Topic การเป็น Software Tester ที่ดีเป็นแบบไหน
ขออภัย คุณมีการใช้งานร่วมกันเกินโควต้า
โดย Anonymous พฤ 22 ก.พ. 2024 3:32 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
414
พฤ 22 ก.พ. 2024 6:13 pm โดย mindphp View Topic ขออภัย คุณมีการใช้งานร่วมกันเกินโควต้า
SMS OTP ราคาถูกมีความสำคัญอย่างไรกับธุรกิจของคุณ
โดย admeadme พ 21 ก.พ. 2024 11:33 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
376
พ 21 ก.พ. 2024 11:33 am โดย admeadme View Topic SMS OTP ราคาถูกมีความสำคัญอย่างไรกับธุรกิจของคุณ
ที่เปิดเองน่ะรู้ แต่ที่ไม่รู้คือ โดนแอบเอาไปเปิด
โดย Anonymous พ 14 ก.พ. 2024 8:08 pm บอร์ด ถาม - ตอบ ธุรกิจ กฏหมาย ภาษี บัญชี
0
474
พ 14 ก.พ. 2024 8:08 pm โดย บุคคลทั่วไป View Topic ที่เปิดเองน่ะรู้ แต่ที่ไม่รู้คือ โดนแอบเอาไปเปิด
Wordpress เว็บไซต์โหลดช้าแล้วขึ้นแบบนี้บ่อยค่ะ ตอนนี้เข้าหลังบ้าน admin กดเข้าอะไรไม่ได้เลย
โดย Anonymous อ 13 ก.พ. 2024 11:38 am บอร์ด สอบถามปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
0
469
อ 13 ก.พ. 2024 11:38 am โดย บุคคลทั่วไป View Topic Wordpress เว็บไซต์โหลดช้าแล้วขึ้นแบบนี้บ่อยค่ะ ตอนนี้เข้าหลังบ้าน admin กดเข้าอะไรไม่ได้เลย
บริการรับทำ Pentest เจาะระบบเพื่อค้นหาช่องโหว่
โดย admeadme จ 12 ก.พ. 2024 1:45 pm บอร์ด Share Knowledge
0
555
จ 12 ก.พ. 2024 1:45 pm โดย admeadme View Topic บริการรับทำ Pentest เจาะระบบเพื่อค้นหาช่องโหว่
สอบถาม ถ้าต้องดู รหัส SMTP ย้อนหลัง บน Gmail ต้องดูที่ไหนครับ
โดย Thanavat_n ศ 09 ก.พ. 2024 1:25 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
889
ศ 08 มี.ค. 2024 8:14 pm โดย mindphp View Topic สอบถาม ถ้าต้องดู รหัส SMTP ย้อนหลัง บน Gmail ต้องดูที่ไหนครับ
คอมพิวเตอร์คืออะไร
โดย Best1677 พ 07 ก.พ. 2024 3:08 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
387
พ 07 ก.พ. 2024 3:08 pm โดย Best1677 View Topic คอมพิวเตอร์คืออะไร