Home >Web Front-end >CSS Tutorial >How to Dynamically Create CSS Animations with '@-Keyframes'?

How to Dynamically Create CSS Animations with '@-Keyframes'?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-15 02:20:021082browse

How to Dynamically Create CSS Animations with '@-Keyframes'?

Dynamically Creating '@-Keyframe' CSS Animations

To achieve dynamic customization of CSS animations, you can create and insert stylesheet rules on the fly. This approach allows you to override existing styles and control the animation endpoints based on received values.

Solution:

  1. Create a style element:

    var style = document.createElement('style');
    style.type = 'text/css';
  2. Construct the keyframes definition:

    var keyFrames = '\
    @-webkit-keyframes spinIt {\
        100% {\
            -webkit-transform: rotate(A_DYNAMIC_VALUE);\
        }\
    }\
    @-moz-keyframes spinIt {\
        100% {\
            -webkit-transform: rotate(A_DYNAMIC_VALUE);\
        }\
    }';
  3. Replace the placeholder with the desired angle:

    style.innerHTML = keyFrames.replace(/A_DYNAMIC_VALUE/g, "180deg");
  4. Insert the style into the document head:

    document.getElementsByTagName('head')[0].appendChild(style);

This will dynamically create and apply a CSS animation with the specified rotation angle. You can adjust the A_DYNAMIC_VALUE placeholder as needed to rotate based on server-provided values.

By leveraging this technique, you can optimize performance by avoiding native JS animations that can consume significant CPU resources. The dynamic creation of stylesheet rules provides the flexibility to customize animations on the fly, enhancing the user experience without additional external libraries.

The above is the detailed content of How to Dynamically Create CSS Animations with '@-Keyframes'?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
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