- Optimizely Web Experimentation
- Optimizely Personalization
When you implement the Optimizely Web Experimentation snippet according to the best practices, you may wonder how Optimizely Web Experimentation and Optimizely Personalization will affect your site's load speed. Traditional web development best practices dictate that any third-party JavaScript file, like Optimizely Web Experimentation's snippet, should go at the bottom of the page and be loaded asynchronously. This approach is intended to ensure that even if these resources load slowly, they do not affect the user's visual experience.
However, Optimizely Web Experimentation and Optimizely Personalization work by changing the visual experience on the page as the site loads, making these changes before the visitor sees any content. When customers implement the Optimizely Web Experimentation snippet synchronously and in the head
tag, the snippet can execute its changes before the content loads, and customers experience a minimal increase in page load speed.
There are two primary ways that may affect load speed: latency and flashing. Read on to learn:
-
What impacts load speeds.
-
How Optimizely Web Experimentation controls for performance.
-
Best practices to avoid any issues.
Latency
Latency refers to when a page is slow to load or render. This is easily noticeable when a web page takes a long time to display in a browser, images slowly appear, or the site's fonts and styles take a long time to apply to text.
Web pages load through a series of steps as the browser requests and receives all the various resources that make up that page (images, CSS files, JavaScript files). The five basic steps of how a page renders are listed below:
-
DNS Lookup – finding the requested resource's web address (for example,
cdn.optimizely.com
). -
Initial Connection – successfully talking to that resource's address.
-
Time to first byte (TTFB) – receiving the very first piece of information from the resource (for example, the first piece of information from Optimizely's CDN).
-
Download/Time to last byte (TTLB) – receiving the very last piece of information from the resource, thus allowing the resource to render visually (for example, an image) or execute (for example, Optimizely Web Experimentation's JavaScript snippet can begin its functionality).
-
Document Complete – the primary indication that the web page has completed loading all of its resources.
How does Optimizely Web Experimentation or Optimizely Personalization affect how long these steps might take?
Optimizely Web Experimentation and Optimizely Personalization use a Content Delivery Network (CDN), a network of web servers located around the world, to provide service for rendering the snippet according to the steps outlined above.
Optimizely balances every request so it can deliver the snippet to the visitor's browser from the physically closest server and highest-performing CDN. This approach allows the snippet to load as quickly as possible in the browser for as many requests as possible, so that even when loading synchronously, Optimizely does not block other assets on the page. You may read more about Optimizely Web Experimentation's approach to CDN balancing here.
Optimizely Web Experimentation and Optimizely Personalization dynamically load-balance between the fastest and most widely used CDNs in the world. This makes the round trip as part of TTFB shorter and reaches TTLB sooner, so Optimizely Web Experimentation and Optimizely Personalization can make changes on the site that much longer before Document Complete. This approach dramatically decreases response times for 99% of website visitors, and allows customers to maximize the ROI from experiments.
If you have any questions about our approach to the delivery of the snippet or have a load speed report from your site that you would like us to review with you, contact support.
Flashing
Flashing, sometimes also called flickering, refers to when a page loads the original content for a short time before loading different content, creating a noticeable "flash" of the page. This can create a disruptive experience for website visitors and distract from the effectiveness of the tested content.
When using Optimizely Web Experimentation or Optimizely Personalization, please consider the following:
-
Placement on Page – Place the snippet as high in the
head
tag as possible. Unlike most third-party scripts, the snippet affects the visual user experience and not just collects data on it. It is important to load Optimizely Web Experimentation and Optimizely Personalization before other content on the page to provide the desired visitor experience.
Search Engine Optimization (SEO) historically advises third-party scripts be placed low on the page. However, Google permits and encourages A/B or multivariate tests and has stated that testing poses no inherent risk to a site's search rank. Read more about AB Testing and Search Engine Optimization. -
Synchronous vs. Asynchronous Loading – Loading the snippet on a page asynchronously increases the risk of flashing on the page. Learn more about synchronous and asynchronous snippet loading.
-
Tag Manager – Do not put the snippet in your tag management system, such as Google Tag Manager.
If you do decide to load Optimizely Web Experimentation or Optimizely Personalization through a tag management system make sure to place it high on the page, set Optimizely Web Experimentation or Optimizely Personalization to load first, and load synchronously. This will help ensure Optimizely Web Experimentation or Optimizely Personalization can execute quickly and make changes before the original page loads. Read more about proper Google Tag Manager or other tag manager implementations. -
Snippet Size – The size of the Optimizely Web Experimentation snippet can greatly impact how testing affects your load time. The snippet contains the information of any running experiments, all audience and goal definitions, and the jQuery library.
Some simple best practices for controlling the snippet's size include archiving completed experiments, writing reused code in Project JavaScript, or removing jQuery if the library already exists at a higher point in thehead
tag.
Please sign in to leave a comment.