有趣的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

相关推荐

  • CSS中contain的语法使用场景

    CSS中contain的语法使用场景 在CSS中,contain是一个有用的属性,用于指定元素的内容是否独立于其外部样式和布局。它可以帮助开发者更好地控制页面布局和优化性能。本文将介绍contain属性的语法使用场景,并提供具体的代码示例。 contain属性的语法如下: contain: layo…

    2025年12月24日
    000
  • CSS中float布局介绍

    CSS中的float布局介绍 在网页开发中,我们经常会用到CSS来控制页面的样式和布局。其中,float布局是一种常用的布局方式。它可以实现元素的浮动效果,使得多个元素并排显示。本文将介绍float布局的用法和常见应用,并提供具体的代码示例。 一、float布局的用法 使用float属性 在CSS中…

    2025年12月24日
    000
  • 网页布局中的元素选择器的应用

    元素选择器在网页布局中的应用,需要具体代码示例 随着互联网的不断发展,网页设计和布局变得越来越重要。为了实现网页的美观和功能,我们需要使用 CSS (层叠样式表)来定义网页的外观和样式。而元素选择器是 CSS 中最常用和基本的选择器之一,它能够帮助我们对页面上的元素进行精确的定位和样式设置。 一、元…

    2025年12月24日
    000
  • 使用正确的CSS布局单位,创造精美的网页设计

    选择合适的CSS布局单位,打造优雅的网页设计 在网页设计中,CSS布局单位是至关重要的一部分。不同的布局单位可以帮助我们更好地控制网页元素的大小、间距和位置,从而打造出优雅、美观的网页设计。本文将介绍几种常见的CSS布局单位,并提供具体的代码示例。 像素(px)单位 像素是最常见的CSS布局单位之一…

    2025年12月24日
    000
  • 使用CSS实现响应式图片卡片布局的技巧

    使用CSS实现响应式图片卡片布局的技巧 随着移动设备的普及和网络速度的提升,人们在浏览网页时越来越重视页面的响应式布局。作为页面设计的关键元素之一,图片在响应式布局中扮演着重要角色。本文将介绍一种使用CSS实现响应式图片卡片布局的技巧,帮助你在不同设备上展示美观且兼容的图片卡片。 实现响应式图片卡片…

    2025年12月24日
    000
  • CSS Flexbox布局:利用弹性盒子布局实现灵活的布局结构

    CSS Flexbox布局:灵活的布局结构实现 简介:在前端开发中,页面布局是一个重要的环节。传统的布局方式,如使用浮动或定位,有时候在设计不符合标准化的情况下会出现一系列问题。为了克服这些问题,CSS3引入了Flexbox布局,它可以为开发者提供更灵活和强大的页面布局解决方案。 Flexbox布局…

    2025年12月24日
    000
  • 从零开始的CSS开发项目经验:从布局到样式的完美呈现

    作为现代Web开发的基本技能之一,CSS的设计和开发能力在许多前端工作中都扮演着关键的角色。然而,随着技术的不断发展,CSS也变得更加复杂和灵活,如何从零开始进行CSS开发成为了许多初学者的难题。在这篇文章中,我们将分享一些从零开始的CSS开发项目经验,帮助大家从布局到样式的完美呈现。 一、布局设计…

    2025年12月24日
    000
  • CSS技巧:如何实现居中对齐的布局

    CSS技巧:如何实现居中对齐的布局 在网页设计中,居中对齐的布局经常被使用。无论是居中对齐文字、图片、还是整个页面布局,都可以通过CSS来实现。本文将介绍几种实现居中对齐的布局的CSS技巧,并提供具体的代码示例。 首先,我们来看如何实现水平居中对齐的布局。下面是一些常见的元素的代码示例: 文字居中对…

    2025年12月24日
    000
  • CSS布局教程:实现瀑布流式卡片布局的最佳方法

    CSS布局教程:实现瀑布流式卡片布局的最佳方法 引言:在现代网页设计中,瀑布流式卡片布局是非常流行的一种布局方式。它能够有效地展示大量的内容,并且在不同的屏幕尺寸下都能够自适应,给用户带来良好的浏览体验。本文将介绍实现瀑布流式卡片布局的最佳方法,并提供具体的代码示例。 一、实现瀑布流式布局的原理 瀑…

    2025年12月24日
    000
  • 如何通过CSS写出适配不同屏幕尺寸的响应式布局

    如何通过CSS写出适配不同屏幕尺寸的响应式布局 在今天的移动互联网时代,人们使用各种设备来访问网页,如智能手机、平板电脑、笔记本电脑等。这使得我们开发网页时,需要考虑不同屏幕尺寸的设备,同时提供优秀的用户体验。为了实现这一目标,响应式布局成为了一个非常重要的概念。 响应式布局是一种通过使用CSS媒体…

    2025年12月24日
    000
  • CSS布局技巧:实现全屏滚动效果的最佳实践

    CSS布局技巧:实现全屏滚动效果的最佳实践 在现代网页设计中,全屏滚动效果成为了一种非常流行的页面交互方式。通过全屏滚动,可以使网页内容以页面为单位进行切换,给用户带来更加流畅和视觉上的丰富体验。本文将介绍一些CSS布局技巧,帮助开发者实现全屏滚动效果的最佳实践。 HTML布局结构在实现全屏滚动效果…

    2025年12月24日
    000
  • CSS布局教程:实现流体布局的最佳方法

    CSS布局教程:实现流体布局的最佳方法 引言:在Web开发中,布局是一个关键的概念。一个好的布局能够使网页看起来整洁、美观,并且在不同设备上都能完美呈现。而其中一种常见的布局方式就是流体布局。本文将介绍如何使用CSS实现流体布局,并提供具体的代码示例。 什么是流体布局?流体布局是指网页布局可以根据浏…

    2025年12月24日
    000
  • CSS Positions布局与网页导航的优化技巧

    CSS Positions布局与网页导航的优化技巧 在网页设计与开发中,布局和导航是两个非常重要的方面。合理的布局可以使网页看起来整洁、美观,而优化的导航则可以提高用户的体验和效率。在这篇文章中,我们将介绍CSS Positions布局和网页导航的一些优化技巧,并提供具体的代码示例。 一、CSS P…

    2025年12月24日
    000
  • CSS Positions布局实现交互效果的创意方法

    CSS Positions布局实现交互效果的创意方法 随着Web技术的不断发展,用户对于网页的交互性要求也越来越高。除了简单的点击和滚动之外,设计师们也开始通过CSS Positions布局来实现更加丰富的交互效果。本文将介绍一些创意的方法,并给出具体的代码示例。 Sticky Sidebar(吸顶…

    2025年12月24日
    000
  • CSS Positions布局与移动端网页开发的技巧

    CSS Positions布局与移动端网页开发的技巧 在移动设备上开发网页需要考虑到屏幕的尺寸和触控操作,因此对于网页的布局和样式需要做一些特殊的处理。CSS Positions是一种常用的布局方式,可以帮助我们在移动端开发中实现一些灵活的效果。本文将介绍CSS Positions的基本概念和用法,…

    2025年12月24日
    000
  • 如何使用Css Flex 弹性布局创建响应式卡片布局

    如何使用Css Flex 弹性布局创建响应式卡片布局 在现代网页设计中,响应式布局是一种必不可少的设计方式。而弹性布局(Flexbox)是一种强大而灵活的布局模型,可以让我们更轻松地创建响应式布局。本文将介绍如何使用Css Flex 弹性布局创建一个简单的响应式卡片布局,并提供具体的代码示例。 创建…

    2025年12月24日 好文分享
    000
  • 如何使用CSS Positions布局实现元素的流体布局

    如何使用CSS Positions布局实现元素的流体布局 在Web开发中,实现元素的流体布局是一项重要的技能。CSS Positions布局是一种常用的方法,可以帮助我们实现元素的自适应和流动性。本文将介绍如何使用CSS Positions布局来实现元素的流体布局,以及具体的代码示例。 CSS Po…

    2025年12月24日
    000
  • 如何使用CSS Positions布局实现弹性网格

    如何使用CSS Positions布局实现弹性网格 CSS Positions布局是网页布局中常用的一种方式,它可以实现弹性网格的效果,让网页元素在不同设备上自适应显示。在本文中,我们将介绍如何使用CSS Positions布局来实现弹性网格,并提供具体的代码示例。 一、理解CSS Position…

    2025年12月24日
    000
  • CSS Positions布局实现网页加载动画的技巧

    CSS Positions布局实现网页加载动画的技巧 在当今互联网时代,网页设计越来越注重用户体验,其中网页加载动画是吸引用户注意力的重要元素之一。而CSS Positions布局是一种常用的网页布局方式,通过合理运用它,可以实现网页加载动画的效果。本文将介绍如何利用CSS Positions布局实…

    2025年12月24日
    000
  • CSS Positions布局实现多列等高布局的方法

    CSS Positions布局实现多列等高布局的方法 在网页开发中,实现多列等高布局是一个常见的需求。传统的方法是使用JavaScript来实现,但是这种方法存在兼容性和性能问题。现在我们可以通过使用CSS Positions布局来实现多列等高布局,不仅简单易用,而且效果良好。 实现多列等高布局的关…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信