吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1558|回复: 0
收起左侧

[其他原创] 【JS】侧边菜单

[复制链接]
梦汐 发表于 2023-3-5 10:55
[Asm] 纯文本查看 复制代码
html = `<div class="paly-list"
style="position: fixed;height:100%;width: 371px;background-color: #ffffff00;z-index: 9999;left: -361px;"
status="hide">
<div class="paly-client-area" style="position: absolute;height:100%;width: 360px;background-color: #ffffff;">

</div>
<div class="show" style="position: absolute;height: 32px;width: 10px;right: 0px;background-color: rgb(255, 255, 255);bottom: 10px;opacity: 1.1;display: block;box-Shadow: 0px 0PX 5px rgb(0 0 0 / 50%);">
</div>
</div>`
const temp = document.createElement('template');
temp.innerHTML = html.trim();
document.body.prepend(temp.content.firstChild);

document.querySelector(".show").onclick = function () {
    var status = document.querySelector(".paly-list").getAttribute('status')
    if (status == "hide") {
        paly_list_show()
    }
}
document.querySelector(".paly-list").addEventListener('contextmenu', function (event) {
    event.preventDefault(); //取消默认的右键菜单
    var status = document.querySelector(".paly-list").getAttribute('status')
    if (status == "show") {
        paly_list_hide()
    }
});

function paly_list_show() {
    var div = document.querySelector(".paly-list");
    div.style.transition = "transform 0.5s ease-out";
    div.style.transform = "translateX(+361px)";
    div.setAttribute('status', "show")

    var client = document.querySelector(".paly-client-area")
    client.style.boxShadow = "5px 0 10px rgb(0 0 0 / 10%)"

    fadeOut(document.querySelector(".show"))
    function fadeOut(element) {
        let op = 1;  // 将不透明度设置为 1
        element.style.opacity = op;
        let timer = setInterval(function () {
            if (op <= 0) {
                clearInterval(timer);
                element.style.display = "none";  // 隐藏元素
            }
            element.style.opacity = op;
            op -= 0.2;  // 每次减少不透明度 0.1
        }, 50);  // 每隔 50 毫秒执行一次
    }
}
function paly_list_hide() {
    var div = document.querySelector(".paly-list");
    div.style.transition = "transform 0.5s ease-out";
    div.style.transform = "translateX(0px)";
    div.setAttribute('status', "hide")

    fadeIn(document.querySelector(".show"))

    function fadeIn(element) {
        let op = 0;  // 将不透明度设置为 0
        element.style.opacity = op;
        element.style.display = "block";
        let timer = setInterval(function () {
            if (op >= 1) {
                var client = document.querySelector(".paly-client-area")
                client.style.boxShadow = "none"
                clearInterval(timer);
            }
            element.style.opacity = op;
            op += 0.2;  // 每次增加不透明度 0.1
        }, 50);  // 每隔 50 毫秒执行一次
    }
}

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 01:06

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表