1. 京东图片列表
开发准备

本来我们是想直接右键图片另存为的,但是发现并没有该选项,应该是京东对图片做了一定的限制
不过,这不妨碍我们获取这些图片,当然你也可以采用截图的方式获取,这里我们采用另外一种方式
通过 F12 可以看到,img元素的src属性,我们将三张图片的这些地址 copy 出来,直接在地址栏进行访问
这里就可以进行图片另存为了,当然你也可以直接在src上填写这些地址
不过,细心的同学会发现,这张图片的格式是jpg.webp后缀结尾的
因为我是在谷歌浏览器中访问的,而谷歌浏览器有自己的特有的一种图片格式 webp(这个我们在第三节-字符实体与语义标签中介绍过)
当然这个格式不是谷歌自己进行转换的,而应该是京东做了不同浏览器之间的适配,即不同的浏览器传递不同格式的图片
Q:怎么验证这种说法呢?
A:我们可以打开非 Chrome 内核的浏览器,使用 F12 查看img的src地址就会发现不一样的地方了
这里我用微软自带的 IE 浏览器(温馨提示:微软官宣定于 2022 年 6 月 15 日完全停止对 IE 的支持)
对比就可以发现,无非就是在 Chrome 浏览器里后缀名多了一个.webp而已
知道这个原理,我们除了可以直接在图片另存为保存为jpg格式,其实还可以直接修改 url 地址
最后,我们将下载的图片放入assets(自定义目录)工程目录下即可
布局剖析
我们使用 F12 进行调试,可以看到京东图片列表的具体元素及属性

- 整体使用一个
li元素包裹,里面又套了一层 div`元素,宽高比:190:470 - 每张图片使用一个
img元素,同时分别用a元素包裹,宽高比:190:150 - 三张图片高度和为 1503=450 < 470,注意到图片之间存在 210px 的外边距
这样,整个京东的图片列表的整体布局就非常清晰了
但是,我们不会那么去实现代码。因为li元素应该包裹在ul元素或者ol元素中,而这里并没有遵循 css 中的语义标签使用规范
我们先看一下这么写会有什么问题
效果
由于使用了 reset 样式,浏览器的默认样式被我们去除了。但是使用ul包裹的li元素和使用div包裹的li元素存在明显的区别:
- 使用
ul包裹的li元素是没有默认样式的 - 使用
div包裹的li元素前仍然存在黑点
我想是因为京东在这里实现了自己的样式替换,所以为了避免重复 reset 默认样式,我们采用正常的列表标签
结构搭建
到这里我们基本骨架已经有了,不过因为没有写 css 样式,图片几乎占据了整个浏览器页面
样式添加
方式 1
还记得上面分析对布局结构的分析吗?
我们首先调整整体的宽高比和单个图片的宽高比
当然这只是其中写法,我们还可以换个思路,退一步来思考
方式 2
我们呢不去限制图片的宽或高,而是对超出ul元素部分(溢出部分)进行隐藏
但是因为图片本身的大小还没有做限制,所以图片保持了原来的图片比例和大小
小剧场: 我们发现下载下来的图片分辨率大小为 380*300,宽和高都刚好是浏览器中图片宽高的 2 倍 这只是巧合么? 不!这是京东为了高分辨率设备而做的适配,保证在一些高清屏下也能够保持清晰
那我们再对图片添加固定的宽或高不就行了?
不!我们直接指定宽或高的话,overflow属性不就显得多此一举嘛
我们给 img 元素设定一个100%的width属性
Q:为什么不能用**auto**呢?
A:我们前一节-盒模型中讲过,水平布局必须要满足一个等式,不满足即存在过渡约束,会做自动调整
而ul元素是块元素,块元素什么特点?独占一行啊!
图片宽度为 380px,浏览器宽度为 1920px(我本机中最大化浏览器的宽度)
现在的等式为0 + 0 + 0 + 380px + 0 + 0 + 0 = 1920px
这七个值中没有auto的情况,所以浏览器会自动调整margin-right值以使等式满足0 + 0 + 0 + 380px + 0 + 0 + (1920-380)px = 1920px
所以如果使用auto属性值,整个过程中图片的width不会发生变化,展现出来的效果就依然是裁剪的样式
Q:为什么**100%**可以呢?
A:我们知道100%是会按照父元素计算的,img的父元素是a,a的父元素是li,li的父元素是ul
也就是说,由于我们没有给a和li单独设置样式,因此img最终会根据ul的宽度计算
而如果只调整图片的宽或高,图片是会保持原比例进行缩放的
所以这个时候就相当于给img设置了一个width=190px的属性值
细节完善
背景色
通过颜色拾取器,识别背景色(我这里使用的是FastStone Capture中自带的Screen Color Picker)
外边距
根据布局剖析结果,我们给每个li元素添加一个 10px 的下边距
Q:为什么是给**li**元素添加呢?
A:我们在调整布局结构的时候,特别是设置外边距,一般是设置块元素的,而不建议去调整行内元素或行内块元素
最终效果
核心代码
2. 京东左侧导航条
开发准备
布局剖析

- 整体使用
ul和li元素,宽高比=190px:470px,其中上下存在 10px 的内边距(影响盒子大小)和 10px 的外边距(影响盒子布局)

li中每个元素也比较简单,用a包裹文字,用span包裹斜杠- 每个
li元素的宽高比=190px:25px,其中左边存在 18px 的内边距(注意右边是不存在的)

- a 元素没有什么大的布局,
span元素左右存在 2px 的内边距结构搭建

我们引入reset.css样式来去除浏览器的默认样式
到这里,基本的骨架就有了
Q:那有些人会问了,我们不是引入了**reset.css**重置了浏览器的默认样式吗?为什么超链接还有样式?
A:其实,如果仔细看 reset.css 的源代码,会发现a元素只是重置了一些基本的内外边距、边框和字体大小,并没有做完全把a元素的样式去除。这个下面会具体介绍样式添加
根据布局剖析,我们可以直接设置整体的样式
到这里整体样式就添加完毕,但我们发现有点问题
别急!我们继续进行细节上的样式调整和优化细节完善
要求效果
目前的效果
两个主要问题
- 要求效果文字居中显示,而我们的文字偏左上角,底部有一定间距
- 文字存在换行和重叠现象
文字调整
只需要给li元素添加一行属性
文字虽然在一行上了,但是依然有重叠问题啊,需要怎么处理呢?
要知道文字有几个属性:
- 文字大小
- 文字颜色
- 文字样式
我们通过 F12 看下这些属性
废话少说,直接写代码
我们这里先不写text-decoration属性,看下效果
写上text-decoration属性,再看下效果
这里可以看到文字下划线消失了,因为我们使用的a标签包裹文字,而超链接具有一定的文字样式(就是蓝色字体带下划线),所以text-decoration属性就是调整文字样式的
到这里,我们的重叠问题还是没有解决
稳住,我们能赢! 我们再对比下要求的效果和我们现在的效果

看出来区别了吗?(当然重点不是我们的背景色,这无关紧要)
我们是把/符号用span包裹起来的,但是我们的/符号似乎又大又粗
符号调整

废话少说,上代码
不过到这里,还是存在问题,我把span元素的内边距去除才可以 (这里我没搞清楚为什么,知道的小伙伴可以评论或私信我哦;不过对比各个元素的盒子模型没什么区别,而且字体样式我也调整了;而且总感觉~~/~~符号之间间隙大了一点,这里存疑先不管了,我们继续往下)
悬浮样式

我们注意到,当鼠标悬浮在某一行时,其背景颜色会有变化;同时,悬浮在某一个超链接上时,字体颜色变红
这里要用到一个伪类选择器:hover,我们还是直接上代码
至此,我们的京东左侧导航栏的前端样式就基本完成了
最终效果
核心代码
存疑问题
通过一番折腾和研究,终于发现问题的关键所在
因为在编写 HTML 代码时,每个li元素中的a的span标签都是换行的
而 HTML 中会将多个空格合并成一个,所以a的span之间都多了一个空格
有几种解决这个问题的方式
- 一是调整 HTML 中每个
li元素中的代码,使之在一行上 - 二是给 ul 元素或 li 元素设置一个
font-size: 0的属性值 - 三是通过 js 去除多余的换行字符(目前还没有学习到,所以不用这种方式,而且较麻烦)
我这里采用第二种方式
到这里,我们往往会忍不住赞叹一下自己:Nice !
3. 网易新闻列表

有了上面的实战步骤,对于网易新闻列表,我们就不进行那么详细的剖析了,直接上代码
结构搭建
样式添加


