<jQury动态布局>浮动子元素均分布局

简介: 在前端页面的布局过程中,作者遇到了,这样一个问题当子元素为浮动元素时,父元素设置相应属性后可以被子元素撑开,但无法实现子元素的均分布局,在网络上找了半小时的资料,没有符合要求的布局示例,今天自己用jQuery实现了动态计算子元素的margin,实现了子元素的均分布局,特来分享一下.

在前端页面的布局过程中,作者遇到了,这样一个问题
当子元素为浮动元素时,父元素设置相应属性后可以被子元素撑开,但无法实现子元素的均分布局,在网络上找了半小时的资料,没有符合要求的布局示例,
今天自己用jQuery实现了动态计算子元素的margin,实现了子元素的均分布局,特来分享一下...

先上效果图

parent_son

源码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        .clearfix:before, .clearfix:after{
            content: "";
            display: table;
        }

        .clearfix:after{

            clear:both;
        }

        /*适配非主流浏览器(IE浏览器)*/
        .clearfix{

            zoom:1;

        }

        .parent{

            width:100%;
            border-width: 1px;
            border-style: solid;
            border-color: #d29922;
            margin: 0 auto;
        }


        .son{

            width:  150px;
            height: 150px;
            border: 2px solid #509839;
            margin: 10px;
            float: left;
            text-align: center;
        }

    </style>

    <script src="js/jquery-1.12.4.min.js"></script>
    <script>

        $(function(){
            // 平均分布子级元素
            function ave_son_element() {
                // 动态获取父标签宽度
                var parent_width = $(".parent").width();
                $("#p_width").text(parent_width);
                // 获取子标签宽度
                var son_width = $(".son:first").outerWidth();
                $("#s_width").text(son_width);

                // 取余数
                var remainder = parent_width % son_width;
                // 取整数商
                var quotient = (parent_width-remainder) / son_width;
                $("#quotient").text(quotient);
                // 获取子元素左右margin值
                var margin_value = parseInt((parent_width - ((son_width)* quotient)) / (quotient*2));
                $("#margin_value").text(margin_value);

                // 设置子元素左侧margin
                $(".son").css("margin-left", margin_value);
                // 设置子元素右侧侧margin
                $(".son").css("margin-right", margin_value);

            }

            // 页面渲染时 平均分布 子级元素
            ave_son_element();

            $(window).resize(function () {
                // 父级 尺寸变化时, 平均分布子级元素

                ave_son_element()

            });

        })



    </script>

</head>
<body>

<div class="parent clearfix">

    <div class="son">君不见</div>
    <div class="son">黄河之水</div>
    <div class="son">天上来</div>
    <div class="son">奔流到海</div>
    <div class="son">不复回</div>
    <div class="son">高堂明悲白发</div>
    <div class="son">朝如青丝暮成雪</div>
    <div class="son">人生得意须尽欢</div>
    <div class="son">莫使金樽空对月</div>
</div>


<div>

    <span>父标签宽度:</span><span id="p_width"></span><br>
    <span>子标签宽度(包含border):</span><span id="s_width"></span><br>
    <span>单行子级标签个数为:</span><span id="quotient"></span><br>
    <span>子级标签左右的margin值为:</span><span id="margin_value"></span>

</div>

</body>
</html>

对应的完整源码,以及jQuery在这里

http://www.jianshu.com/p/4f28e1ae08b1

目录
相关文章
|
7月前
|
前端开发
CSS布局:浮动 (结构伪类选择器、伪元素、标准流、浮动、清除浮动)
CSS布局:浮动 (结构伪类选择器、伪元素、标准流、浮动、清除浮动)
38 0
|
2月前
自定义视口高度,多余的部分使用滚动
自定义视口高度,多余的部分使用滚动
flex 布局子元素被挤压的问题
flex 布局子元素被挤压的问题
|
6月前
|
UED 容器
如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局
如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局
45 0
|
9月前
盒子模型、浮动、定位
盒子模型、浮动、定位
|
前端开发
css:grid布局子元素被撑开导致没有按比例均分
css:grid布局子元素被撑开导致没有按比例均分
273 0
css:grid布局子元素被撑开导致没有按比例均分
|
容器
Flex弹性盒子布局实现骰子6点
Flex弹性盒子布局实现骰子6点
106 0
Flex弹性盒子布局实现骰子6点
认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法(3,此节不全)
通过本章认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法。
61 0
|
前端开发
认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法(4)
通过本章认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法
111 0
认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法(2)
内边距会影响盒子的可见框的大小,元素的背景会延伸到内边距,盒子的大小由内容区、内边距和边框共同决定。外边距指的是当前盒子与其他盒子之间的距离,他不会影响可见框的大小,而是会影响到盒子的位置。
144 0
认识盒子模型,盒子模型的边框、内外边距、水平布局、垂直布局、设置浮动、处理高度塌陷的基本方法(2)