CSS3 simple cutting carousel picture implementation code

CSS3 simple cutting carousel picture implementation code

Implementation ideas

  • First, create a parent container and use two unordered lists to divide the parent container into two columns through flexible layout.
  • When storing images in li, you can divide the images into two columns by giving the left li {background: url('image address') no-repeat; background-size: 200% 100%;} and the right li {background-position-x: -300 (half the width of the parent container) px;}.
  • Give ul the {ransform-style: preserve-3d; } attribute to enable the browser's 3D display.
  • Use child and parent to stack the li together ul{position: relative;} li {position: absolute;}.
  • Set the rotation of li through the transform property.
  • Here you can add .box:hover>ul { transition: all 5s;transform: rotateX(360deg); } to see the effect.
  • Finally, add two buttons to allow users to switch images themselves.
  • When clicking, just change the rotation angle of ul
  btn1.onclick = ()=>{
            item++;
            let r = item * 90;
            letf.style.transform = 'rotateX(' + r + 'deg)';
            letf.style.transition = 'all 1s';
            right.style.transform = 'rotateX(' + r + 'deg)';
            right.style.transition = 'all 1s .3s';
        }
        btn2.onclick = ()=>{
            item--;
            let r = item * 90;
            letf.style.transform = 'rotateX(' + r + 'deg)';
            letf.style.transition = 'all 1s';
            right.style.transform = 'rotateX(' + r + 'deg)';
            right.style.transition = 'all 1s .3s';
        }

Finally, attach all the codes, I hope it will be helpful for you to learn the front-end

HTML code

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Cut the carousel image</title>
</head>
<body>
    <div class="box">
        <ul class="letf">
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
        <ul class="right">
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </div>
    <button id="btn1">Previous page</button><button id="btn2">Next page</button>
</body>
</html>

CSS Code

*{
    margin: 0;
    padding: 0;
}
body{
    perspective: 800px;
}
.box{
    display: flex;
    width: 600px;
    height: 350px;
    margin: 150px auto;
}
.box:hover ul li:nth-child(1){
    transition: all 5s;
    transform: rotateX(360deg);
}
ul{
    flex: 1;
    list-style: none;
    padding: 0;
    margin: 0;
    transform-style: preserve-3d; /* Enable 3D display in the browser*/
    position: relative;
}
li{
    width: 100%;
    height: 100%;
    position: absolute;
}
li:nth-child(1){
    background: url('../images/9.jpg') no-repeat;
    background-size: 200% 100%;
    transform: translateZ(175px);

}
li:nth-child(2){
    background: url('../images/10.jpg') no-repeat;
    background-size: 200% 100%;
    transform: rotateX(90deg) translateZ(175px);
}
li:nth-child(3){
    background: url('../images/11.jpg') no-repeat;
    background-size: 200% 100%;
    transform: rotateX(180deg) translateZ(175px);
}
li:nth-child(4){
    background: url('../images/12.jpg') no-repeat;
    background-size: 200% 100%;
    transform: rotateX(-90deg) translateZ(175px);
}
.right li{
    background-position-x: -300px;
}

js code

  let item = 0;
        let btn1 = document.getElementById('btn1');
        let btn2 = document.getElementById('btn2');
        let letf = document.querySelector('.letf');
        let right = document.querySelector('.right')
        btn1.onclick = ()=>{
            item++;
            let r = item * 90;
            letf.style.transform = 'rotateX(' + r + 'deg)';
            letf.style.transition = 'all 1s';
            right.style.transform = 'rotateX(' + r + 'deg)';
            right.style.transition = 'all 1s .3s';
        }
        btn2.onclick = ()=>{
            item--;
            let r = item * 90;
            letf.style.transform = 'rotateX(' + r + 'deg)';
            letf.style.transition = 'all 1s';
            right.style.transform = 'rotateX(' + r + 'deg)';
            right.style.transition = 'all 1s .3s';
        }

This is the end of this article about the implementation code of CSS3 simple cutting carousel. For more relevant CSS3 cutting carousel content, please search 123WORDPRESS.COM’s previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

<<:  Implementation of Vue top tags browsing history

>>:  Several common methods for passing additional parameters when submitting a form

Recommend

How to modify the ssh port number in Centos8 environment

Table of contents Preface start Preface The defau...

Implementation example of Vue+Element+Springboot image upload

Recently, I happened to be in touch with the vue+...

Mini Program to Implement Paging Effect

This article example shares the specific code for...

Centos7.3 How to install and deploy Nginx and configure https

Installation Environment 1. gcc installation To i...

Nginx configuration location matching rules example explanation

The scope of nginx configuration instructions can...

Implementation of two basic images for Docker deployment of Go

1. golang:latest base image mkdir gotest touch ma...

Detailed process of using vmware to test PXE batch installation server

Table of contents 1. Preparation 1. Prepare the e...

Implementation steps for setting up the React+Ant Design development environment

Basics 1. Use scaffolding to create a project and...

JavaScript implements the nine-grid mobile puzzle game

This article shares the specific code for JavaScr...

Summary of some related operations of Linux scheduled tasks

I have searched various major websites and tested...

Detailed explanation on reasonable settings of MySQL sql_mode

Reasonable setting of MySQL sql_mode sql_mode is ...

How to view image information in Docker

In this article, we will need to learn how to vie...