zoukankan      html  css  js  c++  java
  • 可拖拽可扩展面板

    <!DOCTYPE html>
    <html>
    
        <head>
            <meta charset="utf-8">
            <title></title>
            <style>
                * {
                    margin: 0;
                    padding: 0;
                }
                .panel {
                     400px;
                    height: 200px;
                    background-color: azure;
                    position: absolute;
                    left: 100px;
                    top: 100px;
                }
                .title {
                     100%;
                    height: 20px;
                    line-height: 20px;
                    text-align: center;
                    color: white;
                    font-size: small;
                    background-color: darkgrey;
                    cursor: pointer;
                }
                .dr {
                    position: absolute;
                     30px;
                    height: 100%;
                    right: -15px;
                    top: 0;
                    /*background-color: red;*/
                    
                    cursor: e-resize;
                }
                .db {
                    position: absolute;
                    height: 30px;
                     100%;
                    bottom: -15px;
                    /*    background-color: blue;*/
                    
                    cursor: n-resize;
                }
            </style>
        </head>
    
        <body>
            <div class="panel">
                <div class="title">可扩展panel</div>
            </div>
    
            <div class="panel">
                <div class="title">可扩展panel</div>
            </div>
        </body>
    
    </html>
    <script>
        function drag(obj, opanel) {
            var disx = 0;
            var disy = 0;
            resizable(opanel);
            obj.onmousedown = function(e) {
                var e = e || event;
                disx = e.clientX - opanel.offsetLeft;
                disy = e.clientY - opanel.offsetTop;
                document.onmousemove = function(e) {
                    var e = e || event;
                    opanel.style.left = (e.clientX - disx) + "px";
                    opanel.style.top = (e.clientY - disy) + "px";
                }
                document.onmouseup = function() {
                    document.onmousemove = null;
                    document.onmouseup = null;
                }
                return false;
            }
        }
    
        function resizable(objpanel) {
            var db = document.createElement("div");
            db.className = "db";
            var dr = document.createElement("div");
            dr.className = "dr";
            var drb = document.createElement("div");
            drb.className = "drb";
            objpanel.appendChild(db);
            objpanel.appendChild(dr);
            objpanel.appendChild(drb);
            resize(db, objpanel, "db");
            resize(dr, objpanel, "dr");
            resize(drb, objpanel, "drb");
        }
    
        function resize(objdiv, objpanel, type) {
            var disx = 0;
            var disy = 0;
            objdiv.onmousedown = function(e) {
                var e = e || event;
                disx = e.clientX - objdiv.offsetLeft;
                disy = e.clientY - objdiv.offsetTop;
                document.onmousemove = function(e) {
                    var e = e || event;
                    objdiv.style.left = e.clientX - disx;
                    objdiv.style.top = e.clientY - disy;
                    switch (type) {
                        case "drb":
                            objpanel.style.width = e.clientX - disx+15 + "px";
                            objpanel.style.height = e.clientY - disy+15 + "px";
                            break;
                        case "dr":
                            objpanel.style.width = e.clientX - disx +15+ "px";
                            break;
                        case "db":
                            document.title = e.clientY - disy;
                            objpanel.style.height = e.clientY - disy +15+ "px";
                            break;
                    }
                }
                document.onmouseup = function() {
                    document.onmousemove = null;
                    document.onmouseup = null;
                }
                return false;
            }
        }
        window.onload = function() {
            drag(document.getElementsByClassName("title")[0], document.getElementsByClassName("panel")[0]);
            drag(document.getElementsByClassName("title")[1], document.getElementsByClassName("panel")[1]);
        }
    </script>
  • 相关阅读:
    Sqlite3:Sqlite3命令行Linux操作
    Docker:docker部署Sqlite3数据库
    SpringBoot:Sqlite3+SpringBoot2.1.3+Mybatis-Puls整合项目
    Algorithm:Java加密解密之MAC(消息认证码)
    Springboot:SpringBoot2.0整合WebSocket,实现后端数据实时推送!
    windows10系统安装anaconda后CMD命令行里面的python默认版本变化的问题
    在树莓派中,minicom的一些使用方法
    树莓派软硬串口对调
    树莓派无显示屏连接wifi教程
    设备管理器添加到桌面
  • 原文地址:https://www.cnblogs.com/fierceeagle/p/4530614.html
Copyright © 2011-2022 走看看