HTML——表白(效果+代码)

  • Post author:
  • Post category:其他




目录



效果

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述



代码

demo.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>入我相思门,知我相思苦</title>
    <link rel="icon" href="./image/ax.png" type="image/x-icon" />
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/t.css">
</head>
<body>
    <canvas id="c">
    </canvas>
    <div class="snowback">
        <div class="ziti" id="ziti">
            <span id="world">山有木兮木有枝,心悦君兮君不知</span>
        </div>
        <div class="main">
            <div class="box">
                <ul class="zhoxian1">
                    <li class="small idv1"><img src="./image/img/1.jpg" alt=""></li>
                    <li class="small idv2"><img src="./image/img/2.jpg" alt=""></li>
                    <li class="small idv3"><img src="./image/img/3.jpg" alt=""></li>
                    <li class="small idv4"><img src="./image/img/4.jpg" alt=""></li>
                    <li class="small idv5"><img src="./image/img/5.jpg" alt=""></li>
                    <li class="small idv6"><img src="./image/img/6.jpg" alt=""></li>
                </ul>
            </div>
            <div class="box-biger">
                <ul class="zhoxian2">
                    <li class="biger idv7"><img src="./image/img/=1.jpg" alt=""></li>
                    <li class="biger idv2"><img src="./image/img/=2.jpg" alt=""></li>
                    <li class="biger idv3"><img src="./image/img/=3.jpg" alt=""></li>
                    <li class="biger idv4"><img src="./image/img/=4.jpg" alt=""></li>
                    <li class="biger idv5"><img src="./image/img/=5.jpg" alt=""></li>
                    <li class="biger idv12"><img src="./image/img/=6.jpg" alt=""></li>
                </ul>
            </div>
        </div>
    </div>
    <div class="btn btnonlond" onClick="biggen()">
        <img class="btnimg" src="./image/mypic.gif" alt="">
    
    <div class="hiddenbox">
        <div class="audiobox">
            <audio class="myaudio" src="./music/mp3/pygh.mp3" autoplay controls loop></audio>
        </div>
        <input type="text" placeholder="请输入音乐名称">
        <div class="btn inpbtn" onClick="inpbtnc()">放这个</div>
    </div>
</div>
</body>
<script src="./js/jquery.min.js"></script>
<script src="./js/TweenMax.min.js"></script>
<script src="./js/script.js"></script>
<script src="./js/snow.js"></script>
<script>
    var zhoxian = document.querySelector(".zhoxian1");
    var zhoxian2 = document.querySelector(".zhoxian2");
    var yesno = 1;
    setInterval(function xuanzhuan() {
        if (yesno > 2) {
            var ss = Math.random();
            if (ss < 0.5) {
                leftbut();
            } else {
                rigthtop();
            }
        } else {
            yesno++;
        }
    }, 500);
    var ysize1 = 0,
        xsize2 = 0;
    rigthtop()
    function rigthtop() {
        var suiji = Math.random();
        ysize1 += 1 * (suiji * 20).toFixed(0) + 20;
        xsize2 += 1 * (suiji * 10).toFixed(0) + 10;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    function leftbut() {
        var suiji1 = Math.random();
        ysize1 -= 1 * (suiji1 * 20).toFixed(0) + 20;
        xsize2 -= 1 * (suiji1 * 10).toFixed(0) + 10;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    function onlyleft() {
        var suiji1 = Math.random();
        ysize1 -= 1 * (suiji1 * 20).toFixed(0) + 20;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    function onlyright() {
        var suiji = Math.random();
        ysize1 += 1 * (suiji * 20).toFixed(0) + 20;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    function onlytop() {
        var suiji1 = Math.random();
        xsize2 -= 1 * (suiji1 * 10).toFixed(0) + 10;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    function onlybtn() {
        var suiji = Math.random();
        xsize2 += 1 * (suiji * 10).toFixed(0) + 10;
        var world = `rotateY(${ysize1}deg) rotateX(${xsize2}deg)`;
        zhoxian.style.transform = world;
        zhoxian2.style.transform = world;
        yesno = 0;
    }
    document.querySelector(".box-biger").onmousedown = function (evt) {
        var oevent = evt || event;
        var disx = oevent.clientX;
        var disy = oevent.clientY;
        document.onmousemove = function (evt) {
            var oevent = evt || event;
            evt.preventDefault();
            tuozhuaiX = oevent.clientX - disx + 'px';
            tuozhuaiY = oevent.clientY - disy + 'px';
        }
        document.onmouseup = function () {
            if (parseInt(tuozhuaiX) * parseInt(tuozhuaiX) > parseInt(tuozhuaiY) * parseInt(tuozhuaiY)) {
                if (tuozhuaiX[0] == '-') {
                    onlyleft();
                } else {
                    onlyright();
                }
            } else {
                if (tuozhuaiY[0] == '-') {
                    onlybtn();
                } else {
                    onlytop();
                }
            }
            document.onmousemove = null;
            document.onmouseup = null;
        }
    }
    var moustime = 0;
    document.getElementById("ziti").addEventListener("mouseenter", moveon);

    function moveon() {
        moustime++;
        setTimeout(function () {
            if (moustime == 1) {
                document.getElementById("world").innerHTML = "曾经沧海难为水,除却巫山不是云";
                moveon();
            } else if (moustime == 2) {
                document.getElementById("world").innerHTML =
                    `<span class="iconfont icon-bqxin">人生自是有情痴,此恨不关风与月。<span class="iconfont icon-bqxin">`;
                moveon();
            } else if (moustime == 5) {
                document.getElementById("world").innerHTML =
                    `<span class="iconfont icon-bqxin">身无彩凤双飞翼,心有灵犀一点通<span class="iconfont icon-bqxin">`;
            } else {
                moveon();
            }
        }, 2000)
    }
    document.getElementById("ziti").addEventListener("mouseleave", function () {
        moustime = 0;
        document.getElementById("world").innerHTML =
            `<span class="iconfont icon-bqxin">人生若只如初见,何事秋风悲画扇<span class="iconfont icon-bqxin">`;
    });
</script>
<script>
    var myaudio = document.querySelector(".myaudio");
    var btnimg = document.querySelector(".btnimg");
    var inpbtn = document.querySelector(".inpbtn");
    var input = document.querySelector("input");
    var isgo = 0;
    function biggen() {
        if (isgo == 0) {
            myaudio.play();
            btnimg.src = "./image/666.gif";
            isgo = 1;
        } else {
            myaudio.pause();
            btnimg.src = "./image/mypic.gif";
            isgo = 0;
        }
    }
    function inpbtnc() {
        var name = input.value;
        if (name == "") {
            alert("请输入名称");
            return;
        }
        var musicname = `./music/mp3/${name}.mp3`;
        try {
            myaudio.src = musicname;
        } catch (err) {
            console.log(111);
            alert("请输入的名称不存在!");
        }
    }
</script>
</html>

script.js

// Customize these...
var n = 300,
    speed = 5,//速度定义
    startSize = rand(100,300);//大小定义

// ...not these
var c = document.getElementById("c"),
    ctx = c.getContext("2d"),
    cw = (c.width = window.innerWidth),
    ch = (c.height = window.innerHeight),
    mousePos = {x:"", y:""},
    img = new Image(),
    particles = [],
    particleNumber = 0,
    Particle = function(index) {
      this.index = index;
      this.dur = (100-rand(9, 90))/speed;
      this.draw = function() {
        ctx.translate( this.x, this.y );
        ctx.globalAlpha = this.alpha;
        ctx.globalCompositeOperation = 'lighter';
        // if (index%1.5==0) ctx.globalCompositeOperation = 'overlay';
        if (index%2==0) ctx.globalCompositeOperation = 'xor';
        ctx.drawImage(img, -this.size/2, -this.size/2, this.size, this.size);
        ctx.translate( -this.x, -this.y );
      }
    };

function setParticle(p, firstRun) {
  var _x = cw*rand(0,1), _y = ch*rand(0,1), _s = startSize;
  if (rand(0,1)>0.3 && mousePos.x!=""){ //console.log(mousePos)
    _x = mousePos.x;
    _y = mousePos.y;
    _s = _s/10;
  }
  var _tl = new TimelineMax()
            .fromTo(p, p.dur, {
                x:_x,
                y:_y,
                size:_s,
                alpha:0
            },{
                size:'+='+String(rand(200,400)),
                bezier:[{alpha:rand(0.15,0.65)},{alpha:0}],
                ease:Power1.easeOut,//ease:Power0.easeNone,
                onComplete:function(){ setParticle(p); }
            });

  if (firstRun) _tl.seek(p.dur*rand()); //fast-forward on first run
}


TweenMax.ticker.addEventListener("tick", function(){
  ctx.clearRect(0, 0, cw, ch);
  for (var i=0; i<n; i++) particles[i].draw();
});


window.addEventListener('resize', doResize)
function doResize() {
  particleNumber = 0;  
  cw = (c.width = window.innerWidth);
  ch = (c.height = window.innerHeight);
  for (var i=0; i<n; i++) {
    TweenMax.killTweensOf(particles[i]);
    setParticle(particles[i], true);
  }
  TweenMax.fromTo(c, 0.3, {alpha:0},{alpha:1, ease:Power3.easeInOut});
}

// First run
for (var i=0; i<n; i++) particles.push(new Particle(i));
doResize();


function rand(min, max) {
  (min) ? min=min : min=0;
  (max) ? max=max : max=1;
  return min + (max-min)*Math.random();
}

img.src=""

t.css

* {
    margin: 0;
    padding: 0;
}
html, body {
    width: 100%;
    height: 100%;
    overflow: hidden;
}
canvas {
    display: block;
    position: absolute;
    z-index: -2;
}

.snowback{
    height: 100%;
    width: 100%;
    overflow: hidden;
    position: absolute;
    z-index: 1;
}
.ziti{
    height: 50px;
    width: 100%;
    font-size: 60px;
    text-align: center;
    position: absolute;
    margin-top: 100px;
    z-index: 11;
}
.ziti span {
    height: 30px;
    width: 100%;
    font-size: 25px;
    font-family: "???è?ˉé?…é?‘";
    text-align: center;
    line-height: 30px;
     /*?…3é”???£? ?*/
    background-image: -webkit-linear-gradient(left, rgb(20, 26, 150), #E6D205 25%, rgb(196, 30, 30) 50%, rgb(41, 197, 111) 75%, rgb(175, 23, 221));
    -webkit-text-fill-color: transparent;
    -webkit-background-clip: text;
    -webkit-background-size: 200% 100%;
    animation: masked-animation 4s infinite linear;
}

/*?…3é”???£? ?*/
@keyframes masked-animation {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: -100% 0;
    }
}
.main{
    width: 200px;
    height: 200px;
    top:calc(calc(50% - 100px));
    margin-left: calc(50% - 100px);
    position: absolute;
}
.box {
    width: 200px;
    height: 200px;
    opacity: 1;
    position: absolute;
    transform: scale(0.8);
}
.box-biger:hover+.box{
    transform: scale(0.8);
}
.box-biger{
    width: 200px;
    height: 200px;
    opacity: 0;
    transition: all 1s;
    position: absolute;
    z-index: 10;
}
.box-biger:hover{
    width: 600px;
    height: 600px;
    opacity: 1;
    margin-top: calc(50% - 300px);
    margin-left: calc(50% - 300px);
}
.box ul {
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    background-color: transparent;
    list-style: none;
    position: absolute;
    transition: all 1s;
    transform-origin: 50% 50% 0;
}
.box-biger ul{
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    background-color: transparent;
    list-style: none;
    position: absolute;
    transition: all 1s;
}
.small {
    font-size: 60px;
    text-align: center;
    display: inline-block;
    width: 100%;
    height: 100%;
    position: absolute;
    box-sizing: border-box;
}
.biger {
    font-size: 60px;
    text-align: center;
    display: inline-block;
    width: 100%;
    height: 100%;
    position: absolute;
    box-sizing: border-box;
}
.small img{
    height: 100%;
    width: 100%;
    opacity: 1;
}
.biger img{
    height: 70%;
    width: 70%;
    margin-top: 15%;
    margin-left: 15%;
    opacity: 0.3;
}
.idv1 {
    background-size: cover;
    left: 0;
    top: 100%;
    transform: translateZ(-100px)  rotateY(180deg)  rotate(180deg);
    transform-origin: top;
}

.idv2 {
    background-size: cover;
    top: 0;
    margin-left: 50%;
    transform: rotateY(90deg);
}

.idv3 {
    background-size: cover;
    left: 0;
    top: 0;
    margin-left: -50%;
    transform: rotateY(90deg);
}

.idv4 {
    transform: rotateX(90deg);
    top: -50%;
}

.idv5 {
    transform: rotateX(270deg);
    top: 50%;
}

.idv6 {
    background-size: cover;
    left: 0;
    top: 0;
    transform: translateZ(100px);
}

.idv7 {
    background-size: cover;
    left: 0;
    top: 100%;
    transform: translateZ(-100px)  rotateY(180deg)  rotate(180deg);
    transform-origin: top;
    transition: all 1s;
}

.idv12 {
    background-size: cover;
    left: 0;
    top: 0;
    transform: translateZ(100px);
    transition: all 1s;
}

.box-biger:hover>ul>.idv7{
    transform: translateZ(-300px)  rotateY(180deg)  rotate(180deg);
}
.box-biger:hover>ul>.idv12{
    transform: translateZ(300px);
}

.btn {
    height: 60px;
    text-align: center;
    line-height: 60px;
    width: 90px;
    margin-left: 20px;
    float: left;
    box-sizing: border-box;
    position: absolute;
    border-radius: 30px;
    z-index: 30;
}
.btn img{
    height: 100%;
    width: 100%;
}
.btn:hover {
    cursor: pointer;
}
.inpbtn {
    height: 40px;
    float: right;
    line-height: 40px;
    margin-left: 200px;
    background-color: pink;
    color: white;
    border-radius: 30px;
}


input {
    height: 40px;
    width: 180px;
    float: left;
    border-radius: 20px;
    font-size: 15px;
}

audio {
    height: 40px;
    width: 350px;
    margin-left: -40px;
    margin-top: -1px;
}

.audiobox {
    height: 40px;
    width: 300px;
    border-radius: 20px;
    overflow: hidden;
}
.btnonlond:hover>.hiddenbox{
    visibility: inherit;
}
.hiddenbox {
    margin-top: -60px;
    margin-left: 100px;
    height: 80px;
    width: 300px;
    transition: all 2s;
    visibility: hidden;
    position: absolute;
    z-index: 30;
}



说明

由于这个项目需要的JS、CSS等代码较多,同时也需要图片素材,因此我已经把整个项目文件上传到“

资源

”中了!欢迎各位下载!!!