zoukankan      html  css  js  c++  java
  • 绝对定位之类的

    1.图片的大小时200 201,我给包含他的div设置的是300 100,下面的div的margin值是60,发现图片会把下面的div给盖住。就算是给下面的div设置了overflow;hidden属性还是不行。加上宽度也是不行的。
    2.下面再给图片设置一个绝对定位。此时div2的位置并没有发生什么变化。
    3.图片为绝对定位之后,我把包含他的div块的高度不设置,发现父元素没有了。然后加上高度,不设置宽度,这样还是有div块的存在的,占满整行。宽高都不设置的时候也是不存在了。
    4.如果一个元素设置绝对定位,但是不给他设置left这些值,他的位置是在哪里。这里的正确答案是:相当于static的默认位置。不是都在左上角。测试:我在图片的父元素里面在加上一个div,发现这个div占了一个小块块之后,图片就被挤到了他下面的那一行。这个位置也就是他之前的默认的static的时候的位置。
    5.现在我来给他设置left这些值。设置了left是300px,发现他是相对于html来偏移的。因为body有一个外边距,他都没有。他是找到距离他最近的一个非static的祖先元素。
    6.如果我把那个他上面的div设置成了inline,他就不见了,图片也就顺势顶上去了。此时我再把这个设置成inline的div里面加上字符,他就会被撑起来。但是此时的图片就跟他在同一行了。如果我是吧他设置成inline-block,发现他就不会消失不见,而是图片和他在一行中显示。inline是该元素挥别显示成内联元素,而inline-block则是会被显示为行内的块元素。把它设置成为了inline元素后发现不论怎么改变他的宽高都是没有作用的,他并没有什么变化。不管宽高有没有。p标签也是一个块级标签,如果把他设置成了inline 的话也是必须里面有东西他才会显示出来,否则是不会的。p就算是作为块级元素也是,必须得里面有元素才能显示出来,跟div一样。p元素应该是有一个默认的外边距。p作为块级元素是可以修改其高度的。然后把它的line-height: 设置和高度一样,则可以使文字居中。
    这些inline的和span标签类似,必须得里面有东西才能显示出来。字体的大小也和span标签里面的是一样的。都是继承与body的字体大小。对span标签设置高度根本不管用。对它设置字体的大小还可以改变器高度。然后改变其line-height; 他的大小也还是没有变,只是。。上图。
    7.若包含绝对定位的元素没有设置宽高,则把它设置成绝对定位,父元素就塌陷了。用div3设置了left top值也是相对于html来说的。
    8.看到了下面的div会覆盖在img上面。猜想他是按照代码的先后顺序来排的。在网上查到了我们使用position实现绝对定位,对父级设置position:relative属性,对其子级设置position:absolute加上left或right和top或bottom实现子级在父级内任意定位。在原始情况下重叠是按DIV代码本身顺序排列,越后输入的DIV盒子其越靠前(浮在上面)。除了改变源代码本身div代码在html顺序,我们还可以使用css z-index实现DIV层排列顺序。
    9.再次测试上面的理论。我又加了一个div他有相对定位,然后让其里面的div绝对定位,那么他现在绝对定位是相对于其父元素,而不是跟之前的一样相对于html。但是他的层叠顺序还是按照代码的顺序来层叠的,我把它放到后面,则层叠在上面。

    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <title></title>
        <style>
           #div1
            {
                margin: 30px;
                background: red;
               width: 300px;
               height: 100px;
            }
           img
           {
               position: absolute;
           }
            #div2
            {
                margin: 60px;
                background: yellow;
                overflow: hidden;
            }
            #div3
            {
                width:200px;
                height: 100px;
                background: red;
            }
        </style>
    </head>
    <body>
    <div id="div1">
    <img src="082211207.jpg"/>
    </div>
    <div id="div2">
        <div id="div3"></div>
    </div>
    
    
    
    </body>
    </html>
  • 相关阅读:
    CSS+HTML+flexible.js+rem实现屏幕缩放适配概念原理解释
    《写给程序员的Python教程》阅读随笔---python禅学(Zen_of_python)
    Python使用sql语句对mysql数据库多条件模糊查询
    request.json和request.form
    Python的flask接收前台的ajax的post数据和get数据
    Echarts世界地图和网页表格数据交互联动
    团队项目简介
    ajax和flask路由传json格式数据出现undefined和object错误
    世界疫情div界面搭建初步
    解决element-ui DateTimePicker 默认日期格式化问题
  • 原文地址:https://www.cnblogs.com/zhuni/p/4734015.html
Copyright © 2011-2022 走看看