As we know Yii2 widget is an object-oriented way of reusing view code or client-side code (containing JavaScript, CSS, and HTML) with lesser logic wrapped in a yii\base\Widget object that we can easily insert and apply in any view of the Yii2.
We will extend the two inbuilt methods - init() and run() of yii\base\Widget for creating the custom widget in Yii2. The init() method initializes the object and the run() method executes the object.
Here we will create widget for - "real-time date/time clock" - using javascript code. The clock output is shown as below -
Below are the steps of creating a custom widget in Yii2 -
- Organizing the folder and files
- Writing the css and js code
- Writing the HTML in the view file of the widget
- Creating assets - css and js - initiation code
- Creating the clock widget class which extends yii\base\Widget
- Using the widget code into view file for getting output
1. Organizing the folder and files
Create a folder named as "clockwidget" in the root of frontend or backend folder. Create two new folder - "assets" and "views" in the "clockwidget" folder. Below is the folder and files structure of the widget - "clockwidget".app_folder_name (frontend or backend)/ - clockwidget/ - assets/ - js/ - clockwidget.js - css/ - clockwidget.css - views/ - clock.php - ClockWidget.php - ClockWidgetAsset.php
2. Writing the css and js code
Create style sheet file and place your css at -frontend or backend/clockwidget/assets/css/clockwidget.css
Below is the css code -
/********Css Style for Clock Widget*************/ .clockband{ margin: 0px auto;font-weight: bold;font-size: 14px;background: #c8d8fb; border:1px solid black;padding:5px;width:600px;text-align:center; margin-bottom: 10px; }Create script file and place your javascript at -
frontend or backend/clockwidget/assets/js/clockwidget.js
Below is the javascript code -
/********Javascript for Clock Widget*************/ function ClockWidget() { var d = new Date().toString(); $('#ClockWidget').html(d); } setInterval(ClockWidget,1000);//clock refresh after 1000ms interval ClockWidget();
3. Writing the HTML in the view file of the widget
Create a PHP file and place your HTML code at -frontend or backend/clockwidget/views/clockwidget.php
Below is the HTML code -
<div class="clockband"> <span id="ClockWidget"></span> </div>
4. Writing assets(css and js) initiation code
We will write the code for registering and managing the assets files(CSS and JavaScript) using Yii2 class yii\web\AssetBundle at -frontend or backend/clockwidget/ClockWidgetAsset.php
Below is the code -
<?php //Asset initiation file namespace frontend\clockwidget; use yii\web\AssetBundle; class ClockWidgetAsset extends AssetBundle { public $js = [ 'js/clockwidget.js' ]; public $css = [ 'css/clockwidget.css' ]; public $depends = [ 'yii\web\JqueryAsset' ]; public function init() { // Instruct AssetBundle where the assets files are $this->sourcePath = __DIR__ . "/assets"; parent::init(); } public $publishOptions = [ //disable caching in ClockWidgetAsset - AssetBundle 'forceCopy' => true, ]; } ?>
5. Creating the clock widget class which extends yii\base\Widget
It is the main logic part of the widget code. We write a widget class for clockwidget by extending the yii\base\Widget. It uses two methods - init() and run().The method init() is used to initialize the code and run() is used for registering the assets bundle(css and js) and rendering the widget output at specified view file(frontend or backend/clockwidget/views/clockwidget.php).
frontend or backend/clockwidget/clockwidget.php
Below is the code -
<?php namespace frontend\clockwidget; use yii\base\Widget; use yii\helpers\Html; class ClockWidget extends Widget { public function init() { parent::init(); } public function run() { //Register css and js into Yii2 AssetBundle ClockWidgetAsset::register($this->getView()); //Rendering the view template or file return $this->render('clock'); } } ?>We use below code for registering css and js into Yii2 AssetBundle -
ClockWidgetAsset::register($this->getView());
The css and js file registeration can be checked by taking view source of the page. Below is the css and js file successful registeration screenshot -
6. Using the widget code into view file for getting output
Finally, to use this widget, simply insert the below code in a view file. In our demo case, we have placed the code in the main.php for getting output at top of the site.Below is the code -
<?php use frontend\clockwidget\ClockWidget;//getting class of clockwidget <?= ClockWidget::widget(); ?> ?>Below is the screenshot of the main.php file which reside at - frontend/views/layouts/main.php
You can view the live demo for this widget at - Click here | Downlod the clockwidget source files
Best Books for Web Development in PHP
1
Programming PHP : Creating Dynamic Web Pages
Book Description
It's the new and updated version of this book - Fourth Edition - that teaches you everything you need to know to build effective web applications using the latest features in PHP 7.4.
The book explains language syntax, programming techniques, and other details using examples that illustrate both correct usage and common idioms.
For those with a working knowledge of HTML, the book contains many style tips and practical programming advice in a clear and concise manner to help you become a top PHP programmer.
The book teaches about fundamentals of the language including data types, variables, operators and flow control statements. It explores about functions, strings, arrays and objects.
It teaches to apply common web application techniques, such as form processing, data validation, session tracking, and cookies.
It teaches to interact with relational databases such as MySQL or NoSQL databases such as MongoDB. It also teaches to generate dynamic images, creating PDF files, and parsing XML files.
You can learn about secure scripts, error handling, performance tuning and other advanced topics in this book.
You can get a quick reference to PHP core functions and standard extensions in this book.
Book details
Format: Kindle Edition, PaperbackRating: 4.6 out of 5
Author: Kevin Tatroe, Peter Macintyre
Print Length: 540 pages
Publication Date: 27 March 2020
Publisher: O′Reilly, 4th edition
Kindle Price: Rs. 1,567.50*
Paperback Price: Rs. 3,614.00*
*Price and stock are correct and available at the time of article publication.
Get it here from Amazon
2
PHP Web Development with Laminas
Book Description
This book teaches how to build fully secure and functional e-commerce applications with PHP using the next generation Zend Framework-Laminas. You can learn to develop modern object-oriented applications with PHP by using Test-Driven Development (TDD) and Behavior-Driven Development (BDD) aided by mature reusable components.
This book provides a practical approach to equip you with the knowledge of the Laminas framework needed to start building web applications based on reuse of loosely coupled components.
You will learn how to build the basic structure of a PHP web application divided into layers. You can understand the MVC components of Laminas and be able to take advantage of the Eclipse platform as a method to develop with Laminas.
Books teach to explore how object-relational mapping is implemented with Laminas-DB, behavior-driven development concepts to sharpen your skills, how to build complete models and reusable components, practice testing How to Create HTML Forms With Laminas-Forms.
By the end of this web development book, you will be able to build completely secure MVC applications in PHP language using Laminas.
Book details
Format: Kindle EditionAuthor: Flávio Gomes da Silva Lisboa
Text-to-Speech: Enabled
Enhanced typesetting: Not Enabled
X-Ray: Not Enabled
Word Wise: Not Enabled
Publication Date: 9 December 2022
Publisher: Packt Publishing
Kindle Price: Rs. 750.74*
*Price and stock are correct and available at the time of article publication.
Get it here from Amazon
3
Getting started with Laravel 9, master the most popular PHP framework
Book Description
This book is for all those who want to build their first application in Laravel 9. This book provides a step-by-step introduction to the writing framework, gets to know its most relevant aspects and focuses above all on practice.
Using this book you will be able to build any basic application with the framework. There are total 19 chapters in this book. Using this book, you will be able to know what are the required software to install Laravel for different operating systems.
In this book you can learn - project creation, database configuration, routing, view controllers, redirection, directive and templating engines in the form of blades, model building, CRUD applications etc.
You can learn to perform common eloquent operations that can be applied to databases using query builders. You can learn how to generate test data using classes.
You can also learn the file upload process. You can learn how to use REST APIs through CRUD type applications in VU3 using Axios requests and web components with Oruga UI.
You can also learn how to configure Browsersync with Laravel to automatically reload applications. You can learn how to protect an app in Vue with the login required to access its various modules using SPA authentication or Laravel Sanctum tokens.
Book details
Format: Kindle EditionRating: 1 out of 5
Author: Andrés Cruz Yoris
Print Length: 453 pages
Publication Date: 8 May 2022
Text-to-Speech: Enabled
Screen Reader: Supported
Enhanced typesetting: Enabled
X-Ray: Not Enabled
Word Wise: Not Enabled
Kindle Price: Rs. 449.00*
*Price and stock are correct and available at the time of article publication.
Get it here from Amazon
4
Learning Drupal as a framework: Your guide to custom Drupal 9. Full code included
Book Description
This book uses PHP> 7.4. This course teaches you about the advanced concepts of Drupal 9, object-oriented PHP and Symfony components.
After the course, you will be able to build a variety of robust and scalable software solutions.
This book discusses advanced topics such as custom entities, entity forms, access controls, events, caching, workflows, and more when building real software.
It gives you powerful and ready-to-use snippets for your next Drupal project with +2400 lines of custom code.
Book details
Format: Kindle EditionRating: 5 out of 5
Author: Stef Van Looveren
Print Length: 282 pages
Publication Date: 17 July 2022
Text-to-Speech: Enabled
Screen Reader: Supported
Enhanced typesetting: Enabled
X-Ray: Not Enabled
Word Wise: Not Enabled
Kindle Price: Rs. 449.00*
*Price and stock are correct and available at the time of article publication.
Get it here from Amazon
5
Getting started with CodeIgniter 4
Book Description
This book is for anyone who wants to build their first applications in CodeIgniter 4 a popular PHP framework, this writing offers a step-by-step introduction to the framework, knowing the most relevant aspects of it, and is focused above all on practice.
The book is aimed at those people who want to learn something new, learn about a framework that has very little documentation, who want to improve a skill in web development, who want to grow as a developer, and who want to continue scaling their path with other frameworks superior to this one.
This book has a total of 15 chapters and consists of explanations and practices. It teaches you how to run the framework, how to configure a database, how to create the first components, how to use of migrations for table management, working with the MVC, how to prepare CRUD application, how to use the routes, grouped routes, their options, and the different types.
You can learn about the use of the session and also of the flash session to save data and present it to the user. You can learn to manage views in a reusable way. You can learn about how to work with HTML forms and apply validations from the server side in CodeIgniter. You can learn about the authentication module with the login interface, and how to build a Rest Api type CRUD that can be consumed with JSON or XML.
You can also learn about generating test data with seeders, how to handle the relational schema of the database, how to do uploading files in the application, how to use libraries and help functions, how to integrate the PayPal platform, etc.
Book details
Format: Kindle EditionAuthor: Andres Cruz
Print Length: 328 pages
Publication Date: 13 May 2022
Text-to-Speech: Enabled
Screen Reader: Supported
Enhanced typesetting: Enabled
X-Ray: Not Enabled
Word Wise: Not Enabled
Kindle Price: Rs. 319.00*
*Price and stock are correct and available at the time of article publication.
Get it here from Amazon
FAQ - Frequently Asked Question
What is Yii used for?
There are several popular frameworks in the PHP scripting language, including the Yii framework, which is component-based. It is known for rapid creation of high performance and secure large scale web applications.
What is Yii and Yii2?
Yii is a high performance and OOP (Object Oriented Programming) PHP framework used worldwide to build large level secure web applications. Yii2 is the latest version of Yii which requires PHP 5.4+ as a primary requirement
Is Yii a framework?
Yes, It is a PHP framework. It is widely used to develop a fast, secure and robust web applications.
Is Yii Framework good?
Yes, it is a good framework which is famous for its high-performance and fast large level web application development.
Who uses Yii?
Many top branded companies in the world use Yii framework for their application development like - General, Discovery, Web Stack, Theionic, Deloitte
What is difference between Yii and laravel?
Laravel is built by combining the functionality of several other PHP frameworks that are known for many reliable applications such as a comfortable migration system, model testing, etc.
Yii is a robust and high-performance PHP framework used to rapidly build a variety of modern web applications.
How does Yii Framework work?
The Yii Framework uses the built-in scaffolding tools - Gii, to create application interfaces through which we can create modules, extensions, and different pages of applications such as models, controllers, views, etc., in a matter of minutes.
0 comments:
Post a Comment