有趣的CSS魔法和布局(代码)

本篇文章给大家带来的内容是关于有趣的CSS魔法和布局(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

前言:布局和样式,是每个前端的必修课。在日常的工作中,也会碰到一些特定场景的布局需求,配合上样式,就能实现一些神奇的效果。我搜罗了一些日常开发中遇到的布局,以及浏览各大网站时碰巧发现的神奇特效写法,在此做个分享。

由于篇幅原因,会分为 2 篇。今天,会先介绍一些有趣而又实用的布局的写法。之后的一篇,将展现样式的神奇魔法。

懒加载占位图自适应

在商城中展示商品图片时,如果图片较多,一种比较好的体验是:会先有一个占位图,目的是为了让页面无抖动,也就是所谓的图片懒加载效果。但是,当遇到适配时就比较头痛,特别是手机的横竖屏切换。如果是通过 JavaScript 计算的话,就可能会出现抖动现象。

本着能用 CSS,就不用 JS 去实现的原则,就有了下面这种方案:

立即学习“前端免费学习笔记(深入)”;

@@##@@
.img-ratio {    width: 100%;    position: relative;    padding-top: 75%;}.img-ratio > img {    width: 100%;    height: 100%;    position: absolute;    top: 0;    left: 0;}

可以适配不同屏幕,只要 UI 提供一张 4:3 的占位图即可。下图展示了不同宽高,但比例相同的 2 张图,都能完美地居中显示。

有趣的CSS魔法和布局(代码)

它的原理是:

根据容器的宽度,按照宽高比例,自动计算出容器的实际大小,并且让容器内的如 img 等子元素自适应宽高。图片父容器宽度 100%,父容器的高度百分比为:100 * 3 / 4 = 75%。图片 absolute 并且完全铺满父容器。

移动端的横向滚动条

移动端的界面,寸土寸金。有时为了控制屏幕的滚动长度,会将一些模块横向排列。但是,横向排列会产生一些布局问题。

比如,移动端的滚动条样式,依赖与手机浏览器,各不相同。一种解决方案是:把滚动轴隐藏掉,但不能 overflow-x:hidden;,不然就滚不动了。然后算好每一个横向的块的宽度,让最右侧的块露出一部分,这样用户就知道右侧的屏幕之外还有内容,可以横向滑动。

又如果横向滚动的宽度是未知的,因为可能会随着业务的需要,改变横向模块的个数,那么横向排布就没法用 float 了。因为用了浮动,就得知道整个横向滚动的宽度,整个的宽度要比浮动块累加起来的宽度更宽,才能保证浮动不换行。

所以,就有了下面这样的写法:

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
.wrapper {    width: 340px;    height: 80px;    overflow: hidden;}.wrapper ul {    height: 96px;    width: 100%;    white-space: nowrap;    overflow-x: scroll;    padding: 0;    margin: 0;}.wrapper li {    display: inline-block;    width: 80px;    height: 80px;    background-color: #ddd;    line-height: 80px;    text-align: center;    font-size: 20px;    margin-right: 10px;}

它的思路是:ul 设置 white-space:nowrap;,li 设置 display:inline-block;。最外层的 p 利用高度差,把横向滚动条藏起来。

2203692657-5c976334038af_articlex.png

顶部导航不定宽的居中展示

一些官网,有顶部导航栏,导航栏的内容区往往需要居中展示,两旁则留白,导航栏的下方可能还有根线或者阴影,作为区分顶部与主体内容。

.center-float {    float: left;    position: relative;    left: 50%;}.center-float > ul {    position: relative;    left: -50%;}

这是居中浮动的一种做法,再配合相对定位。

footer 置底

当页面主内容区高度不够时,footer 依然显示在最下面。这里当然不是指 position: fixed,footer是紧跟在内容区下方的。有 2 种方法。

html 结构如下:

            
....

1、margin & padding

html, body {    height: 100%;}$footer-height: 30px;#content {    min-height: 100%;    margin-bottom: -$footer-height;    padding-bottom: $footer-height;}#footer {    line-height: $footer-height;    text-align: center;}

2、flex 布局

$footer-height: 30px;html {    height: 100%;}body {    min-height: 100%;    display: flex;    flex-direction: column;}#content {    flex: 1;}#footer {    line-height: $footer-height;    text-align: center;}

超宽的背景图片居中

一些传统的门户网站,它们的主内容区宽度大致为 980px 或 1000px 这样的经典宽度。有时候,会把较宽的图片作为整体背景图,居中放置,并且不要横向滚动轴,可以这么做:

.wrapper {    min-width: 1000px;    height: 800px;    background: url(test.jpg) no-repeat center top;}.mainContent {    position: relative;    width: 1000px;    margin: 0 auto;}

::after 实现水平垂直居中

伪元素也能用来实现居中么?当时看到的一感觉就觉得挺神奇的,看下面这个例子:

@@##@@
.wrapper {    width: 300px;    height: 300px;    border: 1px solid #ccc;    text-align: center;}.wrapper::after {    content: '';    display: inline-block;    vertical-align: middle;    height: 100%;}.wrapper > img {    vertical-align: middle;}

水平方向很好理解。垂直方向,可以理解为 ::after 把 img 往下拉到了中间。

本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的CSS视频教程栏目!

206413303-5c9763340afa5_articlex.png有趣的CSS魔法和布局(代码)

以上就是有趣的CSS魔法和布局(代码)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1614307.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 04:11:06
下一篇 2025年12月24日 04:11:23

相关推荐

  • flex作用于box容器上的属性介绍

    本篇文章给大家带来的内容是关于flex作用于box容器上的属性介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1. flex-direction 用于指定flex主轴的方向,继而决定flex子项在flex容器中的位置 row,默认值,表示水平方向从左到右排列,此时水平方向为主轴…

    好文分享 2025年12月24日
    000
  • 选择器(picker)插件的实现方法介绍(代码)

    本篇文章给大家带来的内容是关于选择器(picker)插件的实现方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一个正常的选择器插件是非常细致的,一步一步来描述就是。手指滑动内容跟随手指滚动,当内容到底或触顶的时候就不能在滚动并且内容要一直保持在正确的位置上。 第一步…

    2025年12月24日
    000
  • CSS实现基于用户滚动应用(代码)

    本篇文章给大家带来的内容是关于css实现基于用户滚动应用(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 通过将当前滚动偏移映射到html元素上的属性,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动导航组件。 这是我们将使用的HTML, 当我们向下…

    好文分享 2025年12月24日
    000
  • react中使用css的七种方法介绍(附代码)

    本篇文章给大家带来的内容是关于react中使用css的七种方法介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 第一种: 在组件中直接使用style 不需要组件从外部引入css文件,直接在组件中书写。 import React, { Component } from “…

    2025年12月24日
    000
  • CSS3中box-sizing属性的解析(附代码)

    本篇文章给大家带来的内容是关于css3中box-sizing属性的解析(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 盒模型的组成大家肯定都懂,由里向外content,padding,border,margin. 盒模型是有两种标准的,一个是标准模型,一个是IE模型。 立…

    2025年12月24日 好文分享
    000
  • CSS3中的background-clip属性怎么用

    CSS3中的background-clip属性的用法:【background-clip:border-box|padding-box|content-box】。background-clip属性用于规定背景的绘制区域。 css background-clip属性 作用:规定背景的绘制区域。 (推荐教…

    2025年12月24日
    000
  • css3 icon属性怎么用?

    css3的icon属性用于为创作者提供了将元素设置为图标等价物的能力。 CSS3 icon属性 作用:icon 属性为创作者提供了将元素设置为图标等价物的能力。 语法: icon: auto|URL; auto:使用由浏览器提供的默认通用图标。     立即学习“前端免费学习笔记(深入)”; URL…

    2025年12月24日
    000
  • CSS3 appearance属性怎么用?

    css3 appearance属性用于修改元素的默认的样式,改变元素的外观。 CSS3  appearance属性 作用:appearance 属性允许您使元素看上去像标准的用户界面元素。 语法: appearance: normal|icon|window|button|menu|field; 属…

    2025年12月24日
    000
  • css3 nav-right属性怎么用?

    css3 nav-right属性是一个CSS3属性,用于指定当使用箭头向右的导航键时,向何处进行导航,其语法是“nav-right: auto|id|target-name;”,参数“auto”表示浏览器决定导航到哪个元素。 nav-right属性是一个CSS3属性,用于指定当使用箭头向右的导航键时…

    2025年12月24日
    000
  • text-emphasis属性有什么用

    text-emphasis属性用于把指定的强调标记应用到元素文本中除去分隔符字符(如空格和控制字符)的每个字符。 CSS3  text-emphasis属性 text-emphasis 属性是简写属性,用于在一个声明中设置 text-emphasis-style 和 text-emphasis-co…

    2025年12月24日
    000
  • column-count属性怎么用

    column-count属性时用来指定某个元素应分为多少列数显示的。 CSS3  column-count属性 作用:column-count属性指定某个元素应分为的列数。 语法: column-count: number|auto; 参数: auto:默认值,列数将取决于其他属性,例如:&#822…

    2025年12月24日
    000
  • column-gap属性怎么用

    column-gap属性用于指定的列之间的差距,在指定某个元素应分为多少列之后使用。 CSS3 column-gap属性 作用:column-gap属性用于指定的列之间的差距。 使用条件:在使用column-count属性或column-width属性设置好元素的列数后,column-gap属性才会…

    2025年12月24日
    000
  • column-width属性怎么用

    column-width属性用于指定列的宽度;当没有明确指定元素的显示列数时,可通过该属性设置显示列数。 CSS3  column-width属性 作用:column-width属性用于指定列的宽度。 语法: column-width: auto|length; 参数: auto:由浏览器决定列宽;…

    2025年12月24日
    000
  • text-overflow属性怎么用

    text-overflow属性用于指定当文本溢出包含它的元素时,应该发生的事情。 CSS3  text-overflow属性 作用:text-overflow 属性规定当文本溢出包含元素时发生的事情。 语法: text-overflow: clip|ellipsis|string; clip:修剪文…

    2025年12月24日
    000
  • text-outline属性怎么用

    text-outline属性是用于指定文本轮廓的,通过该属性可以设置轮廓的粗细、模糊半径、颜色。 CSS3  text-outline属性 作用:text-outline 属性规定文本轮廓。 语法: text-outline: thickness blur color; thickness:设置轮廓…

    2025年12月24日
    000
  • css3 text-justify属性怎么用

    text-justify属性用于指定当文本对齐属性text-align设置为”justify”时的齐行方法;该属性规定如何对齐行文本进行对齐和分隔。 CSS3  text-justify属性 text-justify属性指定文本对齐设置为”justify&#822…

    2025年12月24日
    000
  • punctuation-trim属性怎么用

    punctuation-trim属性用于指定是否应修饰,当它出现在一条线,或相邻的另一个全形标点符号字符开头或结束标点字符。 CSS3  punctuation-trim属性 作用:punctuation-trim 属性规定如果标点位于行开头或结尾处,或者临近另一个全角标点符号,是否对标点符号进行修…

    2025年12月24日
    000
  • CSS3 border-image-outset属性怎么用?

    border-image-outset属性用于指定在边框外部绘制 边框图像区域的量,即边框图像超过边框盒的量。 CSS3 border-image-outset 属性 作用:规定边框图像超过边框盒的量。 语法: border-image-outset: length|number; length:表…

    2025年12月24日
    000
  • border-image-repeat属性怎么用

    border-image-repeat属性是用于指定图像边框是否应被重复(repeated)、拉伸(stretched)或铺满(rounded)的。 CSS3  border-image-repeat属性 作用:规定图像边框是否应该被重复(repeated)、拉伸(stretched)或铺满(rou…

    2025年12月24日
    000
  • border-image-slice属性怎么用

    border-image-slice属性用于指定图像边框(顶部、右侧、底部、左侧)的向内偏移;没有具体的单位值,只需要给一个单纯的数字值或者按照百分比设置。 CSS3  border-image-slice属性 作用:规定图像的上、右、下、左侧边缘的向内偏移;会把边框图像切成9个区域:4个角、4边区…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信