• 技术文章 >web前端 >css教程

    纯CSS如何实现分栏宽度拉伸调整

    藏色散人藏色散人2020-07-25 16:07:18转载1527

    相关推荐:《css视频教程

    Html:

    <p class="column">
        <p class="column-left">
            <p class="resize-bar"></p>
            <p class="resize-line"></p>
            <p class="resize-save">
                左侧的内容
            </p>                                            
        </p>
        <p class="column-right">
            右侧的内容
        </p>
    </p

    css

    .column {
        overflow: hidden;
    }
    .column-left {
        height: 400px;
        background-color: #fff;
        position: relative;
        float: left;
    }
    .column-right {
        height: 400px;
        padding: 16px;
        background-color: #eee;
        box-sizing: border-box;
        overflow: hidden;
    }
    .resize-save {
        position: absolute;
        top: 0; right: 5px; bottom: 0; left: 0;
        padding: 16px;
        overflow-x: hidden;
        
    }
    .resize-bar {
        width: 200px; height: inherit;
        resize: horizontal;
        cursor: ew-resize; 
        opacity: 0;
        overflow: scroll;
        max-width: 500px;//设定最大拉伸长度
        min-width: 200px;//设定最小宽度
    }
    /* 拖拽线 */
    .resize-line {
        position: absolute;
        right: 0; top: 0; bottom: 0;
        border-right: 2px solid #eee;
        border-left: 1px solid #bbb;
        pointer-events: none;
    }
    .resize-bar:hover ~ .resize-line,
    .resize-bar:active ~ .resize-line {
        border-left: 1px dashed skyblue;
    }
    .resize-bar::-webkit-scrollbar {
        width: 200px; height: inherit;
    }
    
    /* Firefox只有下面一小块区域可以拉伸 */
    @supports (-moz-user-select: none) {
        .resize-bar:hover ~ .resize-line,
        .resize-bar:active ~ .resize-line {
            border-left: 1px solid #bbb;
        }
        .resize-bar:hover ~ .resize-line::after,
        .resize-bar:active ~ .resize-line::after {
            content: '';
            position: absolute;
            width: 16px; height: 16px;
            bottom: 0; right: -8px;
            background: url(./resize.svg);
            background-size: 100% 100%;
        }
    }

    原理

    利用浏览器非overflow:auto元素设置resize可以拉伸的特性实现无JavaScript的分栏宽度控制。

    webkit浏览器下滚动条可以自定义,其中resize区域大小就是scrollbar的大小,于是,我们可以将整个拉伸区域变成和容器一样高。

    css3自由缩放属性resize

    resize属性的语法及参数

    resize属性主要是用来改变元素尺寸大小的,其主要目的是增强用户体验。

    resize: none | both | horizontal | vertical | inherit

    在css3中 resize 属性指定的值分为以下几种。

    以上就是纯CSS如何实现分栏宽度拉伸调整的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:css分栏
    上一篇:九款纯CSS3绘制的复古相机特效代码 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 如何建立纯css的滑块• php如何修改css属性?• CSS的三种样式形式?• 九款纯CSS3绘制的复古相机特效代码
    1/1

    PHP中文网