悄悄上线:CSS @starting-style 新规则

2023-11-23 02:20

本文主要是介绍悄悄上线:CSS @starting-style 新规则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近 Chrome 117,CSS 又悄悄推出了一个新的的@规则,叫做@starting-style。从名称上来看,表示定义初始样式。那么,具体是做什么的?有什么用?一起了解一下吧

一、快速了解 @starting-style

通常做一个动画效果,你可能会考虑 transition 和 animation

相对于animationtransition使用更简单,但是有一定条件,需要有状态的改变,例如手动添加一个class

div{transform: scale(0)
}
div.show{transform: scale(1)
}

示意如下

image.png

但是,如果这个show是一开始就存在的,比如

<div class="show"></div>

这样在页面打开的时候,肯定也是没有过渡效果的,因为没有状态的变化。

在以前,我们可以换成用animation的方式,这样即使是一开始存在的,也能有动画效果,因为animation是可以自动运行的。

不过到了现在,我们可以用transition的方式来实现了,将上面的例子改写一下

div{transform: scale(1);transition: 1s;
}
@starting-style {div{transform: scale(0);}  
}

这里的@starting-style表示初始样式,相当于在渲染之前就有了一个初始状态,这样也就算有状态变化了

image.png

实际效果如下(每次刷新浏览器都有放大动画)

Kapture 2023-11-08 at 23.02.24.gif

这样,即使不手动添加状态也能触发过渡动效了,这就是@starting-style

二、元素添加时添加过渡

有时候,即使是手动添加class,也无法保证一定能触发过渡动效,比如新创建的元素

const div = document.createElement('div')
div.className = 'show' //过渡无效,直接就生效了
document.body.append(div)

这种情况下,transition就失效了,因为你在添加class的时候元素还未完全渲染。

要解决这个问题,之前也有几种方式

首先是定时器,添加一点点延时

settimeout(()=>{div.className = 'show'
},50)

还有一种方式,主动触发元素的渲染,强制重绘

div.clientWidth // 强制触发重绘
div.className = 'show'

另外,还可以用动画animation来代替,这样也能主动触发动画

.show{animation: ...
}

现在,使用@starting-style也能实现这样的效果

div.show{transition: 1s;
}
@starting-style {div{transform: scale(0);}  
}

下面是一个元素出现过渡效果

Kapture 2023-11-09 at 20.17.31.gif


你也可以访问以下链接查看实际效果(Chrome 117+)

  • CSS @style-rule (codepen.io)')点击预览

这让我想起了之前做过一个message效果,实现原理是这样的,如果页面上还没有 message元素,就先创建,然后添加show类名,让这个元素出现,这里就是通过强制触发重绘实现的

function showMessage(txt){this.timer && clearTimeout(this.timer);var oDiv = document.getElementById('messageInfo');if(!oDiv){oDiv = document.createElement('div');oDiv.className = 'messageInfo';oDiv.id = 'messageInfo';document.body.appendChild(oDiv);}oDiv.innerHTML = '<span>'+txt+'</span>';div.clientWidth; // 强制触发重绘oDiv.classList.add('show');this.timer = setTimeout(function(){oDiv.classList.remove('show');},2000)
}

效果如下,第一次创建的时候也有过渡效果

Kapture 2023-11-09 at 20.52.10.gif

有兴趣的可以回顾之前这篇4年前的文章:css3元素出现动画实例

三、让 display:none 也支持过渡

大家可能知道,当一个元素从display:none变成display:block时,是无法触发过渡效果的,即便有一些过渡属性

div{display: none;transition: 1s;transform: scale(0)
}
div.show{display: block;transform: scale(1)
}

像这种情况下没有过渡效果的,如下

Kapture 2023-11-09 at 22.49.54.gif

不过,现在有了@starting-style,也能轻易实现过渡效果,不管你有没有display:none

/*仅需添加一个初始状态*/
@starting-style {div{transform: scale(0);}  
}

效果如下

Kapture 2023-11-09 at 22.55.33.gif

遗憾的是,从display:block变为display:none是无法触发过渡效果的

另外,原生组件很多的隐藏和显示都是直接通过display:none实现的,例如dialog,可以直接添加@starting-style规则来实现打开动画,而无需改变默认 display

dialog{transition: 1s;
}
@starting-style {dialog{transform: scale(0);}  
}

效果如下

Kapture 2023-11-09 at 23.04.11.gif

你也可以访问以下链接查看实际效果(Chrome 117+)

  • CSS @style-rule display (codepen.io)')

四、总结一下

一个可以改变元素初始状态的新特性,你学到了吗?

  1. transition 需要有状态的改变才能触发过渡效果
  2. animation 无需状态改变,因为可以自动运行
  3. @starting-style 可以改变元素的初始状态,让元素在初次渲染时也有过渡效果
  4. @starting-style 可以在元素添加时直接添加过渡效果
  5. @starting-style 可以让 display:none 也支持过渡

不过像这样的 CSS 特性注定是冷门属性,主要是可替代性太强了,而且不知道什么时候才可以正式投入使用,现在就当提前了解吧。最后,如果觉得还不错,对你有帮助的话,欢迎点赞、收藏、转发 ❤❤❤

这篇关于悄悄上线:CSS @starting-style 新规则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414609

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Python之变量命名规则详解

《Python之变量命名规则详解》Python变量命名需遵守语法规范(字母开头、不使用关键字),遵循三要(自解释、明确功能)和三不要(避免缩写、语法错误、滥用下划线)原则,确保代码易读易维护... 目录1. 硬性规则2. “三要” 原则2.1. 要体现变量的 “实际作用”,拒绝 “无意义命名”2.2. 要让

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路