Skip to main content

Helper function | custom helper function in laravel

 Helper function can be implement both with pure functions and by class based functions.

Helper function can be access anywhere in your app, Event they are autoload as well via composer on every user request.

e.g dd() data dump is an common heler function that we use while debugginh in laravel.

How to implement helper functions

1 . Make a directory in app folder with  helpers name.

Create a file helper.php

Write dummy code in this file

<?php
function message (string $string = '') {
    return 'Hello';
}
?>

2. Now register/set the path of this file in composer.json file

add the path in autoload object like that. I define a files key and assign array to it.Array contains all helper function files path with comma separation.

"autoload": {
    "psr-4": {
        "App\\": "app/"
    },
    "files" : ["app/helpers/helper.php"],
    "classmap": [
        "database/seeders",
        "database/factories"
    ]
},

3. Now run the command to add new changes to your app.

-composer dump-autoload

4. Go to web.php file add a route to test the helper function

Route::get('/helper',function(){
    return message('this is helper function call');
});

Now you can clearly see the output.

Now let make class based helper function.

1. create a file in hlper folder and write code inside it.

<?php

namespace App\helpers;

class Custom {
    public static function uppercase( string $string = ''){
        return 'adnan';
    }
}

2. now set it pass go to app.php inside config directory.At the end you will find "aliases" array define you class path here.

"Custom" => \App\helpers\Custom::class,

3.Now go to web.php file and access that class based helper function

Route::get('/helper/class-based',function(){
    return Custom::uppercase();
});

If you face any error of class not found than run this command
- php artisan config:clear

Thanks for reading.














Comments

Popular posts from this blog

Install MariaDB Latest Version 11.4 in Red Hat Version 9

 This this post i will show you step by step the installation process of mariaDB in red hat version 9. Step1 Run the command to pull the latest updated packages on applications installed in your system. -dnf update If you get Kernal update than reboot the system -reboot Step2 Go to official mariaDB site Make mariadb repository in /etc/yum.repos.d Place the configuration in this file # MariaDB 11.4 RedHatEnterpriseLinux repository list - created 2024-09-24 11:12 UTC # https://mariadb.org/download/ [mariadb] name = MariaDB # rpm.mariadb.org is a dynamic mirror if your preferred mirror goes offline. See https://mariadb.org/mirrorbits/ for details. # baseurl = https://rpm.mariadb.org/11.4/rhel/$releasever/$basearch baseurl = https://mirrors.aliyun.com/mariadb/yum/11.4/rhel/$releasever/$basearch # gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB gpgkey = https://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB gpgcheck = 1 Now install the mariaDB with its dependencies package...

Car Company website Proposal Document.

 Car Company Website Proposal Document. What this website offers and give value to company and its customers. This site will showcase the products (vehicles) with simple and sleek design. It will show high impact vehicles images. The specification of vehicle which user can easily understand and make comparisons.  Features of this website both Front-End and Back-End side. Front-End Features 1. Landing page of website 1.1 This page will display classy look of the web design by showcasing different vehicle high resolution images. 1.2 Overview of all Services the company offering to their valuable customers 1.3 Testimonials Client feedback on your services and satisfaction with vehicle which build long term value to company and customer relationship. 1.4 Window Pop-up for showing  sales and events or any news. 2. Pages on this website 2.1 Services Page This page will demonstrate number of Maintenance Services of vehicles this company offers. Now there are two types of service...

React js Commands

Navigation   1. Install React Router Dom npm install react-router-dom npm install react-router-dom@6