css 中 inset属性 以及简单实现spinner

背景

水文,记录下css属性而已

inset

inset 是 CSS 中的一个简写属性,用于同时设置元素的 toprightbottomleft 四个定位属性。它的设计目的是简化定位相关的样式声明,尤其适合需要同时调整元素四个方向位置的场景。

基本语法

inset 可以接受 1~4 个值,遵循与 marginpadding 类似的简写规则:

css 复制代码
/* 1个值:同时应用于 top/right/bottom/left */
inset: <value>;

/* 2个值:第1个值对应 top/bottom,第2个值对应 right/left */
inset: <value1> <value2>;

/* 3个值:第1个值对应 top,第2个值对应 right/left,第3个值对应 bottom */
inset: <value1> <value2> <value3>;

/* 4个值:分别对应 top、right、bottom、left(顺时针顺序) */
inset: <value1> <value2> <value3> <value4>;

取值类型

inset 支持多种 CSS 长度单位和关键字:

  • 长度单位:pxemrem% 等(例如 inset: 10px 20%
  • 关键字:auto(默认值,由浏览器自动计算)
  • 其他:calc() 计算值(例如 inset: calc(50% - 100px)

与单独属性的对应关系

inset 的简写方式完全等价于分别设置四个方向的属性,例如:

css 复制代码
/* 简写形式 */
inset: 10px 20px 30px 40px;

/* 等价于单独声明 */
top: 10px;
right: 20px;
bottom: 30px;
left: 40px;

再举几个例子:

  • inset: 0;top:0; right:0; bottom:0; left:0;(最常用场景)
  • inset: 10px auto;top:10px; bottom:10px; right:auto; left:auto;
  • inset: 0 20%;top:0; bottom:0; right:20%; left:20%;

使用场景

inset 通常与 position 属性 fixed 属性 配合使用,根据不同的定位方式产生不同效果:

  • position: absolute
    元素相对于最近的「已定位祖先」(position 不为 static 的祖先)定位,inset 控制元素与祖先的边距。
    例:让元素填充整个定位容器(常用作全屏遮罩或背景层):
css 复制代码
.overlay {
  position: absolute;
  inset: 0; /* 完全覆盖父容器 */
  background: rgba(0,0,0,0.5);
}
  • position: fixed
    元素相对于视口(浏览器窗口)定位,inset 控制元素与视口的边距。
    例:固定在页面顶部的导航栏,宽度占满屏幕:
css 复制代码
.navbar {
  position: fixed;
  inset: 0 0 auto 0; /* top:0; right:0; bottom:auto; left:0; */
  height: 60px;
}

以下 fiexd定位 可以实现撑开父元素,原先我们需要设置 width:100% height:100%的 现在直接 inset: 0;即可撑开父元素

js 复制代码
.loading {
      position: fixed;
      inset: 0;
      background: red;
    }

简单实现spinner

我们借助 border border-topborder-radius 可以简化的实现 spinner效果 代码如下

js 复制代码
.spinner {
      width: 100px;
      height: 100px;
      border: 5px solid gray;
      border-left: 5px solid red;
      border-radius: 50%;
      animation: spin 2s linear infinite;
    }

    @keyframes spin {
     from {
        transform: rotate(0deg);
      }
      to {
        transform: rotate(360deg);
      }
    }
相关推荐
清风徐来QCQ8 小时前
js中的模板字符串
开发语言·前端·javascript
成都渲染101云渲染66669 小时前
Houdini+Blender高效渲染方案(高配算力+全渲染器兼容)
前端·系统架构
SuperEugene9 小时前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
极梦网络无忧9 小时前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
Predestination王瀞潞9 小时前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
爱学习的程序媛10 小时前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr10 小时前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹10 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang10 小时前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端
雪碧聊技术10 小时前
前端vue代码架子搭建
前端·javascript·vue.js·前端项目代码框架搭建