Training Details

16 weeks

2pm to 5pm (Afternoon) Weekdays (Mon, Wed, Fri) Weekends (Sat)

1st Floor, Nikky Africana Plaza, 70c Allen Avenue, Obasa Close, Opp UBA, Ikeja, Lagos

PHP and Laravel Software Development Training In Lagos Nigeria

Our PHP and Laravel (LAMP Stack) is beginner-friendly, practical and project-based. It is designed to help participants gain mastery of different technologies and tools that are used to build functional software. It is tailored to help you gain real-world experience that can get you a job and grow your career.

Who should attend

  • Those who are switching career to tech industry.
  • Those who have programming skills but want to take their skill to next level with hands-on projects in order to get promotion or higher paying jobs
  • Those planning to travel abroad and seeking hands-on skill that can make them relevant.
  • Those in managerial position seeking to have knowledge of how software is built

Technologies covered


Learning outcomes

Real-World Project

Build any of the following software - ecommerce, job portal, delivery platform, hospital management system, hotel management system

Fullstack development

Ability to work on either frontend design or backend functionalities such as connecting to database, authentication, validation and more


Learn how to collaborate with other software developers on source code management and version control. Deployment to an online server.

Career Positioning

CV review, interview preparation, LinkedIn profile update, job alert within our alumni community and mentorship

Course Curriculum

Introduction to software development

      Introduction and onboarding

  • Full stack software development road-map
  • How the internet works
  • Project planning process
  • Installation and setup

HTML and the browser

     Overview of HTML

  • Advantages and limitations of HTML
  • HTML Comments
  • Basic HTML tags
  • HTML Elements
  • Heading
  • Paragraphs
  • Text Formatting
  • Quotations
  • Links
  • Images
  • Tables
  • Lists
  • Block and Inline Elements
  • Iframes
  • File Paths
  • Viewport meta tag for Responsive Web Design


HTML Entities

  • Charsets
  • URL Encoding
  • HTML Tags
  • Doctypes
  • HTML Attributes
  • Audio/Video

     Project: Designing job application page and Shopping cart page.

     Key takeaway: Understanding of how to render different HTML elements in the browser.

CSS (Cascading Style Sheets)

     Introduction to CSS

  • Benefits of CSS
  • How to add CSS to HTML
  • Code commenting in CSS
  • Applying Colors
  • Background Styling
  • CSS Borders
  • Margins and Padding
  • Height and Width
  • Box model
  • Outline in CSS
  • Text Formatting
  • Fonts styling
  • Using Icons
  • Linking pages, buttons and images
  • Lists
  • Tables


CSS Properties

  • Overflow
  • Float
  • Align
  • Combinators
  • Pseudo-classes
  • Pseudo Elements
  • Opacity / Transparency
  • DropDowns
  • Styling Forms
  • Website Layout
  • CSS Units
  • Specificity
  • CSS Properties
  • CSS Selectors

     Project: Designing a landing page with HTML and CSS

     Task: Design a personal portfolio page

     Key takeaway: Creating different types of frontend application with HTML and CSS

Tailwind CSS

     Tailwind CSS outline

  • Introduction to Tailwind CSS
  • Why  Tailwind CSS?
  • Advantages of Tailwind CSS
  • Installation of tailwind css


  • Container
  • Box Sizing
  • Display
  • Float
  • Clear
  • Object Fit
  • Object Position
  • Overflow
  • Overscroll Behavior
  • Position
  • Top/Right/Bottom/Left
  • Visibility
  • Z-index


  • Flex Direction
  • Flex Wrap
  • Flex
  • Flex Grow
  • Flex Shrink
  • Order

     Tailwind CSS Grid

  • Grid Template
  • Columns
  • Grid Column Start / End
  • Grid Template
  • Rows
  • Grid Row Start / End
  • Grid Auto Flow
  • Grid Auto Columns
  • Grid Auto Rows
  • Gap


  • Justify Content
  • Justify Items
  • Justify Self
  • Align Content
  • Align Items
  • Align Self
  • Place Content
  • Place Items
  • Place Self


  • Padding
  • Margin
  • Space Between


  • Width
  • Min-Width
  • Max-Width
  • Height
  • Min-Height
  • Max-Height


  • Font Family
  • Font Size
  • Font Smoothing
  • Font Style
  • Font Weight
  • Font Variant
  • Numeric
  • Letter Spacing
  • Line Height
  • List Style Type
  • Placeholder Color
  • Placeholder
  • Opacity
  • Text Alignment
  • Text Color
  • Text Opacity
  • Text Decoration
  • Text Transform 
  • Vertical Alignment
  • White space
  • Word Break


  • Backgrounds

  • Background Image
  • Background Clip
  • Background Color
  • Background
  • Opacity
  • Background
  • Position
  • Background
  • Repeat
  • Background Size
  • Gradient Color
  • Stops


  • Border Radius
  • Border Width
  • Border Color
  • Border Opacity
  • Border Style
  • Divide Width
  • Divide Color
  • Divide Opacity
  • Divide Style
  • Ring Width
  • Ring Color
  • Ring Opacity
  • Ring Offset Width
  • Ring Offset Color


  • Box Shadow
  • Opacity

    Tailwind Filters

  • Filter
  • Blur
  • Brightness
  • Contrast
  • Drop Shadow
  • Grayscale
  • Hue Rotate
  • Invert
  • Saturate
  • Sepia
  • Backdrop Filter
  • Backdrop Blur
  • Backdrop
  • Brightness
  • Backdrop Contrast
  • Backdrop
  • Grayscale
  • Backdrop Hue
  • Rotate
  • Backdrop Invert
  • Backdrop Opacity
  • Backdrop Saturate
  • Backdrop Sepia


  • Border Collapse
  • Table Layout

    Transitions and Animation

  • Transition Property
  • Transition Duration
  • Transition Timing Function
  • Transition Delay


  • Transform
  • Transform Origin
  • Scale
  • Rotate
  • Translate


  • Appearance
  • Cursor
  • Outline
  • Pointer Events
  • Resize
  • User Select


  • Fill
  • Stroke
  • Stroke Width

Design a modern landing page with tailwind
Convert Figma design to the actual web app using tailwind

     Personal project: Design a web app for a Fintech company or other industry using tailwind

     Key takeaway:
Ability to build different types of layout
Design web apps that are responsive
Learn general techniques and best practice

JavaScript Programming

     Introduction to JavaScript

  • Overview of JavaScript
  • Installing Code Editor
  • Developer console
  • Adding JavaScript into HTML
  • JavaScript Statements
  • Basic Syntax
  • Input and output
  • JavaScript Comments
  • Interaction: alert, prompt, confirm

     Variables in JavaScript

  • The use of variables?
  • JavaScript Let
  • JavaScript Const
  • JavaScript Reserved Words

     Data Types

  • Numbers
  • Strings
  • Boolean
  • Array
  • Objects
  • Null
  • Undefined

     JavaScript Operators

  • Arithmetic Operators
  • Assignment operators
  • Comparison Operators
  • JavaScript Unary Operators
  • Ternary Operator
  • Instanceof Operator


  • If-else
  • Switch Case in JavaScript
  • Break and Continue
  • Type Conversion

     Loops in JavaScript

  • For Loop
  • While Loop
  • For-in Loop
  • Differences between for( and for(..of)

     Javascript functions

  • Inbuilt Functions
  • User-defined functions
  • Anonymous Functions
  • Functions as First-Class Citizens
  • Callback Functions
  • Higher order function (map, filter, reduce, find)
  • Understanding variable scopes in JavaScript
  • JavaScript Hoisting
  • JavaScript Strict Mode
  • this in JavaScript

Arrays in JavaScript

  • Basic Array Methods
  • sort() Method
  • Array Iteration Methods

     JavaScript Strings

  • JavaScript String Methods
  • How to create multi-line strings in JavaScript?
  • How to sort strings in JavaScript?


Document Object Model (DOM)

  • Introduction to
  • Document Object Model
  • Select Element By Id
  • Select Elements By Name
  • Select Elements By Tag Name
  • Select Elements By Class Names
  • Select Element By CSS Selectors
  • Traversing elements
  • Get the Parent Element
  • Get Siblings of an Element
  • Get Children of an Element
  • Manipulating elements
  • Create Elements
    Append Child Nodes

     Javascript Form

  • How to Create a Form with the JavaScript?
  • Form validation 

     Event handling

  • Introduction to Events
  • Page Load Events
  • The onLoad Event
  • The DOMContent
  • Mouse Events
  • Keyboard Events
  • Scroll Events

     Storing data in the browser

  • Cookies
  • LocalStorage
  • sessionStorage


  • Template Literals
  • Object Literal Syntax 
  • Default Parameters
  • Rest Parameters
  • Spread Operator
  • Destructuring


  • What is the arrow function
  • Importing and
  • Exporting Modules

Asynchronous JavaScript

  • Promises
  • Async/await

     Error Handling

  • try…catch try…catch…finally
  • Throw an Exception

     JavaScript Runtime

  • Execution Context
  • Call Stack
  • Event Loop

Project. Build a quiz application

Build an income and expense app

Personal project: Create a loan calculator for a loan company

Key takeaway: Learn modern best practices and code patterns.

Get the skills and confidence to really understand JavaScript.

Follow a structured learning path to grow your skills more quickly.

Work on real projects and build your portfolio.

React (JS Library)

Introduction to React

  • What is React JS?
  • Why use React instead of JavaScript
  • Project Overview
  • Roadmap

React Setup

  • Environment Setup
  • Creating New Project
  • Analyzing Project Structure

React basics and components

  • Components & Why React is Component-Based?
  • JSX
  • React Elements
  • Building Component
  • Styling Components
  • Dynamic Data in components
  • Passing data using Props

State and event handling

  • Handling Events in React
  • Why are States required?
  • useState() Hook
  • Form Handling
  • Handling form Submission

Contents conditional rendering

  • Rendering of List
  • Importance of key attribute
  • Conditional Statements & Output

Handling side effects

  • What are side effects & useEffect()
  • UseEffect() hook
  • Cleanup function

HTTP Calls using Axios/fetch

  • Making first network Call with fetch
  • Network call using Axios
  • Handling data and states
  • Async and Await
  • Updating the data


Multipage Single page application with react-router

  • Introduction to routIng
  • What is Routing, how it works & installation
  • Basic Routing
  • Link and NavLink
  • Dynamic Routes
  • Nested Routes
  • Redirection and Not Found Page

Global state management with context

  • What is React Context?
  • React context vs Redux
  • When to use React Context?
  • Application of react context


  • Steps to create a production build
  • Hosting your application online

Project: Design an app that consumes APIs from the backend with search functionality and pagination

Convert Figma design to a real web app using React.

Personal project: Design a web app for a Real Estate company or other industry using React.

Key takeaway:

Get hands-on practice in building various projects using React JS.

You will also be creating an industry-ready single-page web application.

Learn how to deploy and maintain an application.

Build powerful, fast, user-friendly and reactive web apps

PHP Programming

Getting started

  • What is PHP
  • Install PHP
  • Writing your first PHP code

PHP Fundamentals

  • Syntax
  • Variables
  • Constants
  • Comments

Data types

  • Boolean
  • Integer
  • Float
  • String
  • NULL
  • Type Casting


  • Assignment Operators
  • Comparison Operators
  • AND (&&) Operator
  • OR (||) Operator
  • NOT (!) operator

Control flow

  • if
  • if else
  • if elseif
  • switch
  • for
  • while
  • do while
  • foreach
  • break
  • continue


  • Function Parameters
  • Default Parameters
  • Named Arguments
  • Variable Scopes
  • Type Hints
  • Strict Typing


  • Associative Arrays
  • foreach
  • Multidimensional Arrays
  • Spread Operator

Sorting Arrays

  • sort
  • uasort
  • asort
  • usort
  • ksort
  • uksort

Advanced function

  • Anonymous Functions
  • Arrow Functions
  • Variable Functions

Advanced array operations

  • Map Array Elements: array_map
  • Filter Array Elements: array_filter
  • Reduce Array Elements: array_reduce


  • PHP Form
  • PHP filter_has_var
  • PHP filter_var
  • PHP filter_input
  • Form Validation
  • PHP Checkbox
  • Multiple Checkboxes
  • Radio Button
  • Select Option
  • Flash Messages
  • PRG (Post-Redirect-Get)
  • Contact Form
  • File Upload
  • Upload Multiple Files
  • PHP Validation
  • Sanitize Input

PHP Login

  • Registration Form
  • Login
  • FILE I/O
  • Open a File
  • Check a File Exists
  • Read a File: fread() & fgets()
  • Read a File into a String:
  • file_get_contents()
  • Download a File
  • Create Temp File
  • Copy a File
  • Delete a File
  • Rename a File
  • Read CSV Files

String operations

  • Get the Leng of a String: strlen()
  • Search for a Substring in a String: substr()
  • Locate the first Occurrence of a Substring: strpos()
  • Replace All Occurrences of a Substring: str_replace()
  • Join an Array of Strings: implode()
  • Split a string by a separator: explode()
  • Remove Characters from Both Ends of a String: trim()
  • Strip Characters from the
  • Beginning of a String: ltrim()
  • Strip Characters fro the End of a String: rtrim()
  • Prevent XSS Attack: htmlspecialchars()
  • Check If a String contains a Substring: str_contains()
  • Check If a String starts with a Substring: str_starts_with()
  • Check If a String ends with a Substring: str_ends_with()
  • Convert a String to Uppercase: strtoupper()
  • Convert a String to Lowercase: strtolower()
  • Convert the First Character in a String to Uppercase: ucfirst()
  • Convert Each Word in a String Uppercase: ucwords()

Object-oriented programming (OOP)

Objects & Classes

$this Keyword
Access Modifiers: public vs. private

Constructors and destructors

Typed Properties
Readonly Properties

Calling the Parent Constructor
Overriding Methods
The protected Keyword


Static Methods & Properties
Class Constants
Late Static Binding

PHP Magic Methods

Working with objects
Comparing Objects
Cloning Objects
Anonymous Classes


Autoloading Class Files
Autoloading with Composer

Exception handling
throw an Exception
Set Exception Handlers

SQL for database manipulation

Introduction to SQL

  • What is SQL?
  • Create Table Statement
  • ALTER TABLE Statements
  • Rename Columns of a Table
  • Modify Column DataType
  • Drop Columns from Table
  • Rename Tables
  • Drop Tables
  • What is Null Value?

DML Statements

  • Insert Statement
  • Update Statement
  • Delete Statement
  • Truncate Statement
  • Merge Statement

SQL Functions

  • AVG()
  • COUNT()
  • MAX()
  • MIN()
  • SUM()

Select Queries

  • Select Query
  • WHERE Clause
  • GROUP BY Clause
  • HAVING Clause
  • ORDER BY Clause
  • SQL Joins

  • Inner Join
  • Left Join
  • Right Join
  • SQL Operators
  • IN
  • LIKE
  • ALL

SQL Operators

  • IN
  • LIKE

Project: Design a database for a social network

Personal task: Design a database for a school management system

Key takeaway: Ability to design and create a database

Implement the database design

Perform CRUD operation

Laravel Framework

views/templates (blade template )
eloquent model
resource controller
validation using form request
gates and policy
artisan cli

mutators and accessors
global scope
route binding
eloquent relationship
soft delete

events and listeners
event subscribers
admin backend
file upload
Key away:
Ability to build an application with features like register, login and validation.
Being able to creating content, editing, updating and delete (CRUD).
Image upload
Form submission
Role and access control
and other features


  • Source code management/collaboration
  • Deployment to live server

Project: Deployment of Laravel on server

Key takeaway: Understand how the server works and how to deploy your app on the server.


56 reviews on
Emmanuel Ireke
Emmanuel Ireke
A beginner friendly place where everything is broken down bit by bit and I will highly recommend for anyone who is trying to enhance or about to start his/her tech journey.
Vincent Edokpayi
Vincent Edokpayi
Best training ever! With the highly experienced and patient teachers, they carefully nurtured me as I went from 0 to 100. The classes are interactive, flexible and exciting in a very cosy environment. I’ll recommend it to anyone out there who desires to learn a new skill, grow in their career or just become more knowledgeable; notwithstanding your present skill level or having none at all, Tech365 would guide you carefully step-by-step into that you dream of becoming. Well done Tech365!
Deborah Babarinsa
Deborah Babarinsa
Very knowledgeable and experienced tutor.
Akinyele Aje
Akinyele Aje
Tech 365 is a very excellent place to learn. The location is wonderful, the lecture rooms have cool ambience and the tutors are very experienced, knowledgeable and friendly. I came in as a pharmacist and I came out as a techie!
Dosa Comfort
Dosa Comfort
It’s a place where you’ll get value for your money, good teaching with project to improve your learning
ogbonna chidiogo
ogbonna chidiogo
Training in Tech 365 is one of the best decisions I've made so far. Did Data Analytics, I was a novice to Excel or anything Tech( I was unsure I would catch up with the lessons) but my first day in class was Wow!! And the rest like the say is history 😃 Kudos to the Mr Wale.
Bello Ololade
Bello Ololade
My training at tech365 is the best. The teaching, mentoring and everything is top notch!

Our students work at

Frequently Asked Questions

Yes we accept installment payment. You can discuss with our team members on available payment options.

No prior programming experience is required. However, you need to know how to operate the computer efficiently. Our training approach is beginner friendly, and we work on several real world projects to help our student have deeper understanding of each module. 

People prefer Tech365 because our training are:

  • Project-based training
  • Job recommendation
  • World-class support
  • Up-to-date curriculum
  • Career guidance and mentoring
  • Access to support community
  • Certificate of completion
  • Flexible payment plan
  • Flexible timing


Our training is

  • Globally relevant
  • Beginner friendly
  • Futuristic
  • Relevant across industries
  • In high demand
  • Financially rewarding

We do not guarantee job. However, we do refer our students for jobs as different organization do reach out to us to hire our students. Some of our students have gotten job through this process.

Yes, we offer weekend classes for those who can’t attend weekdays due to their job or other reasons

Our training schedule are around January, May and September. You can talk to one of our representative for more information.

Yes our training is physical at Ikeja, Lagos. However, those outside Nigeria or living far away can join us online via zoom. The experience is similar.

Yes. In fact, this is our strength. We are committed to supporting our students to ensure they succeed.

Yes, it is recommended to come with your own laptop as it will help you to practice whatever you are learning. However, we provide laptop that can be used only within our premises if need be.

Yes, we provide internet access to our students.

Depending on your budget, Core i7, 16 GB ram with SSD is best.

However, core i3 or i5 with 4gb or 8gb ram HDD will also work fine.

It can be HP, DELL, Mac or any other brand.

Our Pricing Plans

Best Software Development Training

You can choose available options below based on your need.

Software Development
  • Frontend
  • Backend
Software Engineering
  • DevOps
  • Computer Science Fundamentals
  • Software Engineering Module
  • Data Structure/ Algorithm
  • Frontend
  • Backend
Software Dev/Mobile App
  • Mobile App
  • Computer Science Fundamentals
  • Software Engineering module
  • Data Structure/ Algorithm
  • Frontend
  • Backend


Tech365 is a register ICT Training company in Lagos Nigeria. Over the years, we have training several students in Canada, UK, United States, Nigeria and more

Contact Us
error: Content is protected !!