2020-0325外边距折叠,文档流,盒模型,京东左右侧菜单

外边距折叠

  • 在网页中垂直方向相邻的外边距会发生外边距折叠现象
  • 兄弟元素
    • 兄弟元素间乡里难点垂直外边距会取最大值


      10.png

      外边距详细内容.png

      设置下外边距.png

      最大值.png

      相邻的垂直外边距.png

父子元素外边距折叠

  • 子元素的上外边距会传递给父元素
  • 子元素和父元素相邻的下外边距不会产生任何效果
    12.png

    11.png

    13.png

    box5设置尺寸.png

    Box4外边距设置bottom,box5不会有任何动静
  • 在网页中垂直方向相邻的外边距会发生折叠现象
  • 兄弟元素外边距折叠:
    • 兄弟元素间相邻的垂直外边距会取最大值
  • 父子元素外边距折叠
    • 子元素的上外边距会传递给父元素
    • 子元素和父元素相邻的下外边距不会产生任何效果
  • 兄弟元素间的外边距折叠不需要处理,但是父子元素间的上外边距折叠必须要处理
  • 只有相邻的才会折叠,让他不折叠就不相邻了,给父元素加个上外边框


    14.png

    设置box3的border-top,把两者的外边距隔开.png

兄弟元素外边距折叠

  • 兄弟元素间相邻的垂直外边距会取最大值

行内元素盒模型

  • 两个行内之间有个缝隙,是换行导致的,把两个行内元素连起来就没有了

  • image.png
  • 行内元素不支持宽度和高度的设置,宽高都是由内容决定的
    内边距

  • 上下内边距生效了,没有挤到别的元素,垂直方向内边距不会影响页面布局

  • image.png

    - 边框

    • 行内元素可以设置边框,但是垂直方向的边框不会影响页面的布局

margin

  • 水平方向外边距生效,垂直方向外边距不会影响页面布局,不会挤到别的元素

padding

  • 水平方向内边距生效,垂直方向外边距不会影响页面布局,不会挤到别的元素
  • image.png

文档流(normal flow)

  • 网页是一个多层的结构,一层摞着一层
    • 能看到的只是网页的最上层

    • 在网页的最底层,最基础的层被称为文档流

    • 元素创建后默认都在文档流中排列

      • image.png
    • 元素在文档流里的特点

      • 块元素
        • 在文档流中从上到下垂直排列,也就是所谓的独占一行,如果离开了文档流,块元素就不会垂直排列
        • 元素默认宽度是auto,块元素在文档流中默认宽度是父元素的全部,严格来书尽量把父元素撑满
        • 块元素在文档流中默认高度是被内容撑开的
  • 行内元素
    • 行内元素在文档流中自左向右水平排列,如果一行中不足以容纳所有的行内元素,元素会换到第二行,继续自左向右水平排列(和我们的书写习惯是一致的)


      image.png
1.png
  • 现在所看到的就是默认宽度和高度,行内元素的默认宽度和高度都是被内容撑开的, 同时也不能指定宽度和高度


    2.png

    写个样式.png

    3.png

    4.png

    创建一个span.png

    5.png

    6.png

默认样式

  • 可以通过引入重置样式表,来清除默认样式,重置样式表就是一个专门用来清除默认样式的样式表
    7.png

    8.png

    有个缝隙
    9.png

    p和box有个距离
  • 在网页中,浏览器为了确保网页在没有CSS样式的前提下也可以正常浏览
  • 所以浏览器都会为元素设置一些默认的样式
  • 但是这些默认的样式会影响到我们所编写的样式
    • 并且在不同的浏览器中,默认样式也会有一些差异
    • 所以在编写网页前,我们都需要去除调浏览器的默认样式
      • 先明确距离是谁的
      • HTML盒模型.png

        内容区.png

        默认样式.png

        默认样式2.png

        margin设置为0,就把默认的覆盖了.png

        外边距折叠.png

        image.png

        按住方向键可以修改


        去除项目符号.png

        去除所有样式.png
  • 这种是使用最方便的方式,有可能存在一些样式没有清楚彻底(用于临时开发,或者移动端)
  • 还可以通过引入重置样式表,来清除默认样式
    • 重置样式表就是一个专门用来清除默认样式的样式表

      -
      重置样式表.png

所有元素.png

性能比 * 好一些
重置样式表2.png

  • 重置样式表有两个版本
    • reset.CSS
      • 会直接将浏览器中所有默认样式去除(这个用的多一些)
    • normalize.css
      • 并不是简单去除样式,而是去除那些不必要的,统一那些需要使用的
15.png

16.png
  • 首先清除默认样式


    17.png
  • 先写外边的,再写里面的

设置外部的容器

18.png

设置宽度
width:190px
设置高度
height:470px

设置里边的容器

二倍图.png

是实际图片大小的两倍
设置图片和容器宽度一致
item img{
width:100%
}

19.png

image.png

效果
image.png

image.png

image.png

image.png

最后的外边距能看出来,但是没什么影响

京东左侧菜单

  • 一般情况用ul+li做
  • 这个网页结构的编写方式不是固定的,很灵活
    用nav+div的方式写


    一个div.png
一个这个就是一个div.png
  • 手机,运营商,数码有三个超链接
  • Item是项的意思
  • 斜杠可以直接写/,不过这样不好,一般放到标签里,比如写个<span>/</span>,设置样式的时候好设置
    line是线的意思.png

    先清除默认样式.png

    把内外边距都去除掉
    没有用ul,去掉列表前面的点就不用管了

    Div的宽度直接看网站的数据.png

    li的 宽度190,高度25.png

    设置菜单项的大小.png

    这个时候整个外边的容器就可以了
    字整体往右移动,用padding-left.png

    这个padding用标尺量出来的内边距18px,也可以直接看网站数据.png

    设置一个左padding字就会往右走了.png

    为了保证总宽度190,因为设置了左内边距18,就要用190-18,总宽度就是172px
    设置hover的效果
    设置hover的效果.png

    设置菜单项中链接的样式
    设置菜单项中链接的样式.png

    设置超链接的鼠标移入效果
    修改字体颜色

Text-decoration:none(文本修饰)
作用是去除超链接下划线

现在需要修改斜杠的效果
.item .line{ Font-size:12px;}这是修改线的大小

所有的行内元素都放到一行里,这时候就近了,这种方式是最快的方式.png

控制空格的方法不方便,但是控制margin可以随意控制大小
可以给line(斜杠)设置左右外边距,
Margin:0 2px;
后面的菜单项直接复制,创建一个菜单的容器(nav,专门表示菜单的)
然后直接把菜单项放到menu里,有多少项就复制多少个

设置外部容器的大小
设置外部容器的大小.png

所有菜单项加一起高度450,总高度是470,所以上下内边距各10像素
再调整就去掉背景颜色
先设置居中margin:50-auto;

背景颜色是白色背景,看不出来白色就给body设置背景颜色.png

京东右侧列表

找网页中的图片方法,默认格式是webp.png

如果不想用这个格式,可以把这个.webp删了.png

一个块里放了三个图片.png

这表示整个外层的容器.png

ul写个名字,img-list是图片列表的意思,名字随意写,写语义化方便理解锻炼单词能力.png
image.png

这个类名比较简单,起不起都行,最好还起一个,熟悉一下

图片应该是可以点击的超链接
这时候就有了第一个列表了,后面的直接复制粘贴

image.png

直接写个div,里面放三个图片也行,但是分成三块,这种方式最好用块元素布局,这样处理起来比较简单

图片列表效果(素颜妆),这是刚刚定好结构没有写样式的样子,

image.png

跟左侧无序列表顺序一样,先清除默认样式
先清除内外边距

image.png

去除项目符号.png

一般的顺序先写外边再写里边,根据个人习惯,写的方式不限.png

Img-list没有设置宽度,默认宽度是auto
设置外部容器的大小.png

现在ul是这么大,因为没有给ul设置宽度,ul的宽度默认是全屏的.png

先确定ul的宽度,可以用标尺测量,Ul的宽度190px.png

ul高度470px.png

设置好容器宽,高,颜色.png

ul在这里,因为现在ul的宽度小于图片的宽度,导致ul看不清楚.png

这里设置的背景颜色并不是最终样式,目的是设置一个颜色能看清楚在哪里,在最终效果中没有的,是一个临时的颜色
这个在最后是要删了的.png

现在设置里边的容器,宽度是190,但是实际上图片的宽度是380,这种图片我们叫做二倍图.png

现在很多高清屏或者手机屏,像素比较小,所以图片在高清屏上可能就把图片放大了,如果放1:1的图片,图片放到了就会导致图片不清楚,所以常见的方案一般会设置一个比较大的图片,这样可以确保即使手机对网页缩放两倍,图片也会确保比较高的清晰度,这个时候需要设置图片的大小

图片是li的子元素,所以可以写成.item img{width:100%;}
让图片的宽度和父元素item的宽度是一样的

打开效果,图片就跟不宽了,图片跟容器的宽度一致.png

图片间的距离10px.png

也不一定非要量,容器总高度470,图片高度300,因为是二倍图就除以2就是150,三个150就是450,多了20px,
等于这两个地方都是10px.png

设置li的边距.png

这个时候可以去掉ul的背景颜色.png

跟原图差不多了.png

然后设置外部容器居中
Margin:0 auto; 图片太靠上了

Margin:50px auto;往下拉一拉.png

最后一个li也有一个外边距,在这能看见,但实际上没有任何的影响.png

li的高度是被内容撑开的,图片多高,li就多高.png

图片本身高度300,显示出来是154,比实际高度多了4个像素,item的font-size:0就不会多出4个像素了.png

以后凡是遇到这种问题,图片大小超过了实际大小,解决方式就是给父元素设置font-size:0,

Div写个box1, 样式.box1{border:10px red soli:}

图片和边框没有严格贴合,有缝隙.png

直接在.box1里面写font-size:0,这个缝隙就没了.png

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,451评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,172评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,782评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,709评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,733评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,578评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,320评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,241评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,686评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,878评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,992评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,715评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,336评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,912评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,040评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,173评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,947评论 2 355

推荐阅读更多精彩内容