• 可拖拽可扩展面板


    <!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>
  • 相关阅读:
    [python] pprika:基于werkzeug编写的web框架(6) ——restful的错误处理
    [python] pprika:基于werkzeug编写的web框架(5) ——蓝图blueprint
    [python] pprika:基于werkzeug编写的web框架(4) ——请求上下文与helpers
    [python] pprika:基于werkzeug编写的web框架(3) ——错误处理
    [python] pprika:基于werkzeug编写的web框架(2) ——路由与请求响应
    [python] pprika:基于werkzeug编写的web框架(1) ——序言与简介
    2019寒假训练营第四次作业
    2019寒假训练营第三次作业
    【学习笔记】福州大学网络课程 网络空间安全概论(5)
    【学习笔记】福州大学网络课程 网络空间安全概论(1,4)
  • 原文地址:https://www.cnblogs.com/fierceeagle/p/4530614.html
Copyright © 2020-2023  润新知