Home » Why does Google still use paging instead of progressive loading?

Why does Google still use paging instead of progressive loading?

Solutons:


Infinite scroll has its uses, but a search result page is not one of them. Infinite scroll relies on discovery and exploration. This works well for when you’re not looking for anything in particular; when you’re sifting through a massive amount of data until you find something that hooks your interest. This format lends itself extremely well for social media with newsfeeds, or inspiration platforms like Pinterest.

You may measure the benefits of infinite scrolling with the example of a Facebook news feed. By unspoken agreement, users are aware that they won’t get to see everything on the feed, because the content is updated too frequently. With infinite scrolling, Facebook is doing it’s best to expose as much information as possible to the users and they are scanning and consuming this flow of information.

Search results are all about finding what you need.

Pagination is good when the user is searching for something in
particular within the list of results, not just scanning and consuming
the flow of information.

Google wants to show you relevant data. Pagination tells you where the search results are located (page) and in which order they match your criteria. This helps to estimate how much time it’ll take to find what you’re actually looking for and helps you find results back.

Google has experimented in the past with loading times. Turns out, even with a slightly longer delay in loading, people are more likely to abandon the search. Infinite scroll is rather heavy on performance, so this would multiply this abandoning rate.

More here: https://uxplanet.org/ux-infinite-scrolling-vs-pagination-1030d29376f1

There is no official statement regarding this, so no one can give you a 100% accurate answer.

One of the biggest reasons might be the ad placement of Google.
They earn money with every search, and since they use pagination they can even earn money multiple times with only one search, try it yourself.

For example if you search for “toaster” (in Germany), these are the 1st and 2nd page ads:

First Page top-ad
Search results, with ads to the right

So in short, I think pagination fits Google’s business goals.

Since no one posted it yet, to me the main reason against infinite scrolling is shown in this XKCD comic:

Maybe we should give up on the whole idea of a 'back' button. 'Show me that thing I was looking at a moment ago' might just be too complicated an idea for the modern web.

The tool tip reads:

Maybe we should give up on the whole idea of a ‘back’ button. ‘Show me that thing I was looking at a moment ago’ might just be too complicated an idea for the modern web.

Here is the Explain XKCD page for the comic strip.

Update 1:

I just found the hidden comment above that already mentioned this XKCD comic strip.

Update 2:

To clarify, why I do think my answer is valid here is: To me, the equivalent of the above

“If I touch the wrong thing, I’ll lose my place and have to start over”

is when clicking a SERP entry, going to the destination URL and then clicking the Back button.

This would usually return me to some other location than the previous SERP infinite scroll position where I left.

Related Solutions

How can I stop applications and services from running?

First Things First You may have some misconceptions about how Android works and what's really happening when a service is running or an app is in the background. See also: Do I really need to install a task manager? Most apps (e.g., ones you launch manually)...

How do I reset a lost administrative password?

By default the first user's account is an administrative account, so if the UI is prompting you for a password it's probably that person's user password. If the user doesn't remember their password you need to reset it. To do this you need to boot into recovery...

How can I use environment variables in Nginx.conf

From the official Nginx docker file: Using environment variables in nginx configuration: Out-of-the-box, Nginx doesn't support using environment variables inside most configuration blocks. But envsubst may be used as a workaround if you need to generate your...

Difference between .bashrc and .bash_profile

Traditionally, when you log into a Unix system, the system would start one program for you. That program is a shell, i.e., a program designed to start other programs. It's a command line shell: you start another program by typing its name. The default shell, a...

Custom query with Castle ActiveRecord

In this case what you want is HqlBasedQuery. Your query will be a projection, so what you'll get back will be an ArrayList of tuples containing the results (the content of each element of the ArrayList will depend on the query, but for more than one value will...

What is the “You have new mail” message in Linux/UNIX?

Where is this mail? It's likely to be in the spool file: /var/mail/$USER or /var/spool/mail/$USER are the most common locations on Linux and BSD. (Other locations are possible – check if $MAIL is set – but by default, the system only informs you about...

How can I find the implementations of Linux kernel system calls?

System calls aren't handled like regular function calls. It takes special code to make the transition from user space to kernel space, basically a bit of inline assembly code injected into your program at the call site. The kernel side code that "catches" the...

Is a composite index also good for queries on the first field?

It certainly is. We discussed that in great detail under this related question: Working of indexes in PostgreSQL Space is allocated in multiples of MAXALIGN, which is typically 8 bytes on a 64-bit OS or (much less common) 4 bytes on a 32-bit OS. If you are not...

Explaining computational complexity theory

Hoooo, doctoral comp flashback. Okay, here goes. We start with the idea of a decision problem, a problem for which an algorithm can always answer "yes" or "no." We also need the idea of two models of computer (Turing machine, really): deterministic and...

Building a multi-level menu for umbraco

First off, no need pass the a parent parameter around. The context will transport this information. Here is the XSL stylesheet that should solve your problem: <!-- update this variable on how deep your menu should be --> <xsl:variable...

How to generate a random string?

My favorite way to do it is by using /dev/urandom together with tr to delete unwanted characters. For instance, to get only digits and letters: tr -dc A-Za-z0-9 </dev/urandom | head -c 13 ; echo '' Alternatively, to include more characters from the OWASP...

How to copy a file from a remote server to a local machine?

The syntax for scp is: If you are on the computer from which you want to send file to a remote computer: scp /file/to/send username@remote:/where/to/put Here the remote can be a FQDN or an IP address. On the other hand if you are on the computer wanting to...

What is the difference between curl and wget?

The main differences are: wget's major strong side compared to curl is its ability to download recursively. wget is command line only. There's no lib or anything, but curl's features are powered by libcurl. curl supports FTP, FTPS, HTTP, HTTPS, SCP, SFTP, TFTP,...

Using ‘sed’ to find and replace [duplicate]

sed is the stream editor, in that you can use | (pipe) to send standard streams (STDIN and STDOUT specifically) through sed and alter them programmatically on the fly, making it a handy tool in the Unix philosophy tradition; but can edit files directly, too,...

How do I loop through only directories in bash?

You can specify a slash at the end to match only directories: for d in */ ; do echo "$d" done If you want to exclude symlinks, use a test to continue the loop if the current entry is a link. You need to remove the trailing slash from the name in order for -L to...

How to clear journalctl

The self maintenance method is to vacuum the logs by size or time. Retain only the past two days: journalctl --vacuum-time=2d Retain only the past 500 MB: journalctl --vacuum-size=500M man journalctl for more information. You don't typically clear the journal...