4. View เป็นส่วนการแสดงผล

ใน Joomla 3 ส่วนประกอบ View เป็นรูปแบบเฉพาะหรือการแสดงเนื้อหาของส่วนประกอบส่วนหน้าของเว็บไซต์ แต่ละองค์ประกอบใน Joomla มีหลาย View ที่สามารถเข้าถึงได้โดยการแนบพารามิเตอร์ 'view' กับ URL ของส่วนประกอบ

4.1 สร้างโฟลเดอร์ชื่อ views และสร้างโฟลเดอร์ชื่อ a

4.2 สร้างไฟล์ view.html.php ในโฟลเดอร์ a

สร้างไฟล์ view.html.php ในโฟลเดอร์ a เป็นส่วนการทำ php
สร้างไฟล์ view.html.php ในโฟลเดอร์ a

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

<?php
/**
 * @package	HelloComponent
 * @subpackage	com_hellocomponent
 * @author	Mindphp Developer Teams
 * @copyright	Copyright (C) 2021 Mindphp. All rights reserved..
 * @license	GNU General Public License version 2 or later;
 */
defined('_JEXEC') or die();

class HellocomponentViewA extends Joomla\CMS\MVC\View\HtmlView
{
    function display($tpl = null)
    {
        echo "Test View A<br/>";
        $this->sidebar = JHtmlSidebar::render();

        $this->addToolbar();
        parent::display($tpl);

	}

    public function addToolbar()
    {
        \Joomla\CMS\Toolbar\ToolbarHelper::title(JText::_('COM_HELLOCOMPONENT_A'));
        $cando =  Joomla\CMS\Helper\ContentHelper::getActions('com_hellocomponent');
        \Joomla\CMS\Toolbar\ToolbarHelper::preferences('com_hellocomponent');
    }
}

คำอธิบายโค้ด

  • สร้างคลาสชื่อ HellocomponentViewA (ขึ้นต้นด้วย "ชื่อของ Component" ตามด้วยคำว่า "View" และ "ชื่อของ View") โดยการสืบทอดคุณสมบัติมาจากคลาส Joomla\CMS\MVC\View\HtmlView
  • สร้าง function display เป็นส่วรแสดงผลเทมเพลต และให้ใช้คำสั่ง echo แสดงข้อความ "Test View A" ในหน้า view

 

4.3 สร้างโฟลเดอร์ tmpl และไฟล์ default.php เพื่อใช้ในการกำหนด layout สำหรับ View ที่ชื่อ A

จะเป็นการแสดงผลทางหน้าจอเว็บพวกข้อความต่าง ๆ
สร้างโฟลเดอร์ tmpl และไฟล์ default.php

 

Code ของไฟล์ views/a/tpml/default.php

<?php
/**
 * @package	HelloComponent
 * @subpackage	com_hellocomponent
 * @author	Mindphp Developer Teams
 * @copyright	Copyright (C) 2021 Mindphp. All rights reserved..
 * @license	GNU General Public License version 2 or later;
 */
defined('_JEXEC') or die();
?>

<p>Test Layoul A</p>

4.4 สร้าง View อีกหนึ่ง View โดยใช้ชื่อ B

สร้าง view b
สร้าง view b

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

defined('_JEXEC') or die();

class HellocomponentViewB extends Joomla\CMS\MVC\View\HtmlView
{
    function display($tpl = null)
    {
        echo "Test View B<br/>";
        parent::display($tpl);

	}

}

Code ของไฟล์ views/b/tpml/default.php

<?php
/**
 * @package	HelloComponent
 * @subpackage	com_hellocomponent
 * @author	Mindphp Developer Teams
 * @copyright	Copyright (C) 2021 Mindphp. All rights reserved..
 * @license	GNU General Public License version 2 or later;
 */
defined('_JEXEC') or die();
?>

<p>Test Layoul B</p>

4.4 ต่อไปก็จะไปเพิ่ม view หน้าหลักไปสร้างโฟล์เดอร์ชื่อว่า hellocomponent ซึ่งการสร้างจากคล้ายกับโฟลเดอร์ a และ b

สร้าง view หลัก โดยใช้ชื่อ hellocomponent
สร้าง view หลัก

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

<?php
/**
 * @package	HelloComponent
 * @subpackage	com_hellocomponent
 * @author	Mindphp Developer Teams
 * @copyright	Copyright (C) 2021 Mindphp. All rights reserved..
 * @license	GNU General Public License version 2 or later;
 */
defined('_JEXEC') or die();

class HellocomponentViewHellocomponent extends Joomla\CMS\MVC\View\HtmlView
{
    public function display($tpl = null)
    {
        HellocomponentHelper::addSubmenu('');
        $this->sidebar = JHtmlSidebar::render();

        $this->addToolbar();
        parent::display($tpl);
    }

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

    }
}

Code ของไฟล์ views/hellocomponent/tpml/default.php

<?php
/**
 * @package	HelloComponent
 * @subpackage	com_hellocomponent
 * @author	Mindphp Developer Teams
 * @copyright	Copyright (C) 2021 Mindphp. All rights reserved..
 * @license	GNU General Public License version 2 or later;
 */
defined('_JEXEC') or die();
?>
<?php if (!empty($this->sidebar)) : ?>
    <div id="j-sidebar-container" class="span2">
    <?php echo $this->sidebar; ?>
    </div>
    <div id="j-main-container" class="span10">
<?php else : ?>
    <div id="j-main-container">
<?php endif; ?>
    </div>

 

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
การทำงานกับ Selenium ร่วมกับคำสั่ง if-else
โดย athirach.offcial ศ 29 มี.ค. 2024 3:12 pm บอร์ด Software testing
0
171
ศ 29 มี.ค. 2024 3:12 pm โดย athirach.offcial View Topic การทำงานกับ Selenium ร่วมกับคำสั่ง if-else
การใช้ฟังก์ชัน ScreenShot ใน Selenium เพื่อจัดการการถ่ายภาพหน้าจอของเว็บไซต์
โดย athirach.offcial ศ 29 มี.ค. 2024 3:00 pm บอร์ด Software testing
0
142
ศ 29 มี.ค. 2024 3:00 pm โดย athirach.offcial View Topic การใช้ฟังก์ชัน ScreenShot ใน Selenium เพื่อจัดการการถ่ายภาพหน้าจอของเว็บไซต์
การใช้งานฟังก์ชัน Window ใน Selenium เพื่อจัดการกับหน้าต่างของเบราว์เซอร์
โดย athirach.offcial ศ 29 มี.ค. 2024 2:36 pm บอร์ด Software testing
0
136
ศ 29 มี.ค. 2024 2:36 pm โดย athirach.offcial View Topic การใช้งานฟังก์ชัน Window ใน Selenium เพื่อจัดการกับหน้าต่างของเบราว์เซอร์
การใช้ Selenium เพื่อส่งคีย์ (send_keys) ไปยังฟิลด์ค้นหา
โดย athirach.offcial ศ 29 มี.ค. 2024 1:57 pm บอร์ด Software testing
0
171
ศ 29 มี.ค. 2024 1:57 pm โดย athirach.offcial View Topic การใช้ Selenium เพื่อส่งคีย์ (send_keys) ไปยังฟิลด์ค้นหา
selenium การใช้ driver.get เพื่อเข้าสู่เว็บไซต์โดยอัตโนมัติ
โดย athirach.offcial ศ 29 มี.ค. 2024 1:50 pm บอร์ด Software testing
0
173
ศ 29 มี.ค. 2024 1:50 pm โดย athirach.offcial View Topic selenium การใช้ driver.get เพื่อเข้าสู่เว็บไซต์โดยอัตโนมัติ
พิมพ์ pdf จาก excel สามารถกำหนดให้พิมพ์บนล่างก่อนแล้วค่อยไปพิมพ์ซ้ายไปขวาได้มั้ยคะ
โดย MBMoo ศ 29 มี.ค. 2024 1:34 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
3
196
ศ 29 มี.ค. 2024 1:48 pm โดย mindphp View Topic พิมพ์ pdf จาก excel สามารถกำหนดให้พิมพ์บนล่างก่อนแล้วค่อยไปพิมพ์ซ้ายไปขวาได้มั้ยคะ
เมธอด dict() ในการพัฒนาระบบ Python การสร้างพจนานุกรมอย่างมีประสิทธิภาพ
โดย athirach.offcial พฤ 28 มี.ค. 2024 12:33 pm บอร์ด Python Knowledge
0
312
พฤ 28 มี.ค. 2024 12:33 pm โดย athirach.offcial View Topic เมธอด dict() ในการพัฒนาระบบ Python การสร้างพจนานุกรมอย่างมีประสิทธิภาพ
การใช้งาน filter() กรองตัวเลขหรือตัวอักษรในภาษา Python
โดย athirach.offcial พฤ 28 มี.ค. 2024 12:16 pm บอร์ด Python Knowledge
0
106
พฤ 28 มี.ค. 2024 12:16 pm โดย athirach.offcial View Topic การใช้งาน filter() กรองตัวเลขหรือตัวอักษรในภาษา Python