Skip to main content

2. Data fetching in NEXT JS application.

 NEXT JS provide us three method for data fetching.

1) Server Side Rendering (SSR)

2) Static Site Generation (SSG)

3) Incremental Static Generation (ISG)

                                                    Server Side Rendering (SSR)

    Dynamic server render data. It fetch fresh data/content on each request. With SSR each request to server rendering new cycle for data fetching. It ensure always content up-to-date.

                                                    Static Site Generation (SSG)

NEXT JS component directly/automatically data using API's and store data in server cache. The data store in cache not frequently change.

Such as blog post, documentations, marketing pages etc.

                                               Incremental Static Generation (ISG)

In ISG we provide additional parameter in api endpoint fetch method as an second parameter.

That is { next: { revalidate: 10 }}

It combine the benefits of SSR and SSG  for dynamic and static sites.

But the advantage of ISG is that you can specify certain data to be statically fetch at build time and than fetch dynamically after the revalidate (specified time interval) time.

Note : It much be note data save on server render  component in cache and data save in client render components in useState hook. So you have to make sure with component should be server or client render component.

We need to learn and develop full stack capabilities in next js application, For that we need to make sure few thing in out application.

1) Focus on server-less route handler.

2) As we know NEXT JS app allow us to make full stack application because it run on both server/back-end and client/front-end using the same file routing system.

                                                    Route Handlers in NEXT JS

There are two ways to define handlers in NEXT JS application.

1) File Based route handlers write within the api folder within the app directory.

2) Second approach is to create direct handler within the app directory itself

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...

Redis installation in Red Hat Linux

 In this post we will see step by step installation of Redis service in Redhat/CentOS operation system. To install Redis, run this command in terminal -dnf install redis This command will install the redis service in your machine. Verify installation -systemctl status redis -systemctl start redis -systemctl enable redis Note: Before start redis service set Linux Kernal overcommit memory to 1 by adding vm.overcommit_memory = 1 to /etc/sysctl.conf file. Why we should do that: As we know redis is in memory data store. It primarily uses RAM to store data. Redis and other processes use RAM memory. We set vm.overcommit_memory = 1 to make sure Kernal not overcommit the memory by allocating memory to new program which required more memory than available memory. In this scenario OOM (Out Of Memory) killer terminate the rest of processes. We also restricting Kernal not to terminate the important services running and also stop swapping redis and other importance service to device i/o device,...

Prepared statements, form submission, form validation and displaying errors in php

PHP Code. Insert statement Query. INSERT INTO `users`(`user_id`, `user_first`, `user_last`, `user_email`, `user_uid`, `user_pwd`) VALUES (1,'Adnan','Zaib','text@.com','Admin',1234) What are Prepared statements and how to use them //Created a sql prepare template $sql = "SELECT * FROM users WHERE user_uid=?;"; //than send to database with certain values left(unspecified parameters). //Create a prepared statement $stmt = mysqli_stmt_init($conn);   //prepare the prepared statement if(!mysqli_stmt_prepare($stmt, $sql)){ echo "sql statement failed"; }else{ //bind values to parameters and further to placeholder mysqli_stmt_bind_param(#stmt, "s",); // ‘s’ stands for datatype of parameter that you are going to pass. }   while($row = mysqli_fetch_assoc($result)){ echo $row['user_uid'] . "<br>"; } PHP form Validation   <?php // define variables and set to empty values $name = $email = $gender = $comment = ...