Home Web Front-end JS Tutorial How to Create a CSS3 Blurred Text Link Effect

How to Create a CSS3 Blurred Text Link Effect

Mar 04, 2025 am 01:04 AM

Detailed explanation of the effects of fuzzy text in CSS3 and FAQs

Key Points

  • CSS3 can create blur text effects with transparent text colors and text shadows, but not all browsers support the text-shadow attribute. In this case, you can use Modernizr or write custom text shadow detection code as a workaround.
  • A pleasing effect can be achieved for the navigation menu by smoothly blurring the links in and out while hovering or focusing. This involves defining a "blur" class that can be applied to any link and then using a CSS style that can be applied in all browsers.
  • When creating blurred text effects, be sure to pay attention to accessibility and visibility issues. In addition, the amount of blur can be controlled by adjusting the third text shadow attribute (defining the amount of blur). It can be modified to increase or decrease blur effect.

The following is an example of the text effect I saw on Chris Coyier's CSS Tricks website. Blur text can be created in CSS3 by applying transparent text colors and text shadows:

.blur-text {
  color: transparent;
  text-shadow: 0 0 5px https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b000;
}
Copy after login
Copy after login

How to Create a CSS3 Blurred Text Link Effect

Unfortunately, not all browsers support text-shadow. IE9 and below will apply transparent colors, but no shadow effect - the text becomes invisible. We have to turn to Modernizr or write our own text shadow detection code. The following JavaScript code attaches the "textshadow" class to the HTML element when the browser supports it. So we can use the CSS selector of ".textshadow .blur-text" to ensure that it is applied only if the effect does not cause bad behavior:

if (document.createElement("detect").style.textShadow === "") {
  document.getElementsByTagName("html")[0].className += " textshadow";
}
Copy after login
Copy after login

Warning: Opera's fuzzy behavior Chrome and Firefox display fuzzy text, but are disabled in IE. However, Opera can be weird; it supports text-shadow, but does not want to apply it to transparent text. This seems to be a mistake, as applying the color of rgba(0,0,0,0) will solve the problem.

Fuzzy link

With some extra CSS3 magic, we can make the links smoothly blur in and out when hovering or focusing. This can be a pleasant effect for the navigation menu. We will define a "blur" class (or "blur in" class) that can be applied to any link. The link will start with blur and return to normal focus when activated. Similarly, we will define the "blur out" class that blurs the text when hovering/focusing, i.e.:

<a href="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">开始模糊,结束清晰</a>
<a href="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">开始清晰,结束模糊</a>
Copy after login

We now need basic CSS styles that apply to all browsers—even those that do not support text-shadow:

a.blur {
  text-decoration: none;
  color: https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b339;
}

a.blur:hover, a.blur:focus {
  text-decoration: underline;
  color: https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b933;
}
Copy after login

The next set of styles applies to all .blur elements, regardless of whether they have focus or not:

  • We remove the link underline and outline
  • Set the text color to transparent and
  • Apply CSS3 transitions that animate smoothly between no text shadows and full text shadows. The effect starts after 100 milliseconds and is completed after 400 milliseconds.
.blur-text {
  color: transparent;
  text-shadow: 0 0 5px https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b000;
}
Copy after login
Copy after login

Finally, we define two text shadow states. The third text shadow attribute defines the "fuzzy amount". It will animate between 0 and 4px, but if more or less blur is required, you can modify it:

if (document.createElement("detect").style.textShadow === "") {
  document.getElementsByTagName("html")[0].className += " textshadow";
}
Copy after login
Copy after login

View the link fuzzy demo page - the source code contains all the required CSS and JavaScript. I hope you find it useful, but be careful about accessibility/visibility issues when using this effect. If you use it elsewhere, I'd love to receive your comments and post the URL.

FAQs for fuzzy text effects in CSS3

(The FAQs part is omitted here because it is too long and is highly repetitive with the original content. FAQs can be selectively retained or reorganized as needed and rewritten in a more concise language.)

The above is the detailed content of How to Create a CSS3 Blurred Text Link Effect. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do I create and publish my own JavaScript libraries? How do I create and publish my own JavaScript libraries? Mar 18, 2025 pm 03:12 PM

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

How do I optimize JavaScript code for performance in the browser? How do I optimize JavaScript code for performance in the browser? Mar 18, 2025 pm 03:14 PM

The article discusses strategies for optimizing JavaScript performance in browsers, focusing on reducing execution time and minimizing impact on page load speed.

What should I do if I encounter garbled code printing for front-end thermal paper receipts? What should I do if I encounter garbled code printing for front-end thermal paper receipts? Apr 04, 2025 pm 02:42 PM

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

How do I debug JavaScript code effectively using browser developer tools? How do I debug JavaScript code effectively using browser developer tools? Mar 18, 2025 pm 03:16 PM

The article discusses effective JavaScript debugging using browser developer tools, focusing on setting breakpoints, using the console, and analyzing performance.

How do I use source maps to debug minified JavaScript code? How do I use source maps to debug minified JavaScript code? Mar 18, 2025 pm 03:17 PM

The article explains how to use source maps to debug minified JavaScript by mapping it back to the original code. It discusses enabling source maps, setting breakpoints, and using tools like Chrome DevTools and Webpack.

Who gets paid more Python or JavaScript? Who gets paid more Python or JavaScript? Apr 04, 2025 am 12:09 AM

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

Getting Started With Chart.js: Pie, Doughnut, and Bubble Charts Getting Started With Chart.js: Pie, Doughnut, and Bubble Charts Mar 15, 2025 am 09:19 AM

This tutorial will explain how to create pie, ring, and bubble charts using Chart.js. Previously, we have learned four chart types of Chart.js: line chart and bar chart (tutorial 2), as well as radar chart and polar region chart (tutorial 3). Create pie and ring charts Pie charts and ring charts are ideal for showing the proportions of a whole that is divided into different parts. For example, a pie chart can be used to show the percentage of male lions, female lions and young lions in a safari, or the percentage of votes that different candidates receive in the election. Pie charts are only suitable for comparing single parameters or datasets. It should be noted that the pie chart cannot draw entities with zero value because the angle of the fan in the pie chart depends on the numerical size of the data point. This means any entity with zero proportion

TypeScript for Beginners, Part 2: Basic Data Types TypeScript for Beginners, Part 2: Basic Data Types Mar 19, 2025 am 09:10 AM

Once you have mastered the entry-level TypeScript tutorial, you should be able to write your own code in an IDE that supports TypeScript and compile it into JavaScript. This tutorial will dive into various data types in TypeScript. JavaScript has seven data types: Null, Undefined, Boolean, Number, String, Symbol (introduced by ES6) and Object. TypeScript defines more types on this basis, and this tutorial will cover all of them in detail. Null data type Like JavaScript, null in TypeScript

See all articles