CSS 新的 @position-try 的便利性

css锚点定位前段时间就出来了。如果你和我一样不喜欢编写 css,这个新的 api 肯定会有所改善。

锚定位

css 锚点定位 api 允许开发人员轻松相对于其他元素(称为锚点)定位元素,无需额外的库或复杂的 javascript。此功能非常适合创建菜单、工具提示、对话框和其他分层界面。

使用此 api,您可以确保元素的大小/位置根据其锚点进行调整。这消除了手动调整的需要,并在构建动态、交互式布局时提供更流畅、响应更灵敏的体验。

什么是位置尝试?

anchor css 还推出了一个新的 css at-rule,称为 position-try。 当锚定元素不适合屏幕或容器时,它允许您定义锚定元素的后备位置。如果某个元素溢出,浏览器会自动选择下一个替代位置,确保它保持完全可见和功能正常。 position-try-fallbacks 属性可用于定义浏览器 try 的多个后备位置。早些时候,这可以通过运行一个侦听器来实现,该侦听器在每次视​​口更改后检查事情是否进展顺利。

这可以避免在使用下拉菜单、工具提示等时出现很多令人头疼的问题,因为现在我们不必编写自定义逻辑来检查溢出情况。

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

演示

这是我使用上述 css 属性编写的代码的快速演示:

CSS 新的 @position-try 的便利性

我那丑陋的导航栏中的子菜单会根据视口的宽度改变其位置。

代码是用react编写的。早些时候我必须使用效果来做到这一点。在我的效果中,我会检查子菜单元素是否跨越视口的边界。如果是,我会触发另一个重新渲染来更新子菜单的样式。由于 useeffect 在绘制之后运行,并且我们不希望用户在错误的位置看到子菜单,因此我必须为此使用 uselayouteffect。

现在我所要做的就是编写这样的 css:

.button-anchor {  anchor-name: --anchorButton;}@position-try --bottom {  position-area: bottom;}.menu-list {  position-anchor: --anchorButton;  border: 1px solid #000;  font-family: sans-serif;  width: 60px;  font-size: 12px;  display: flex;  flex-direction: column;  row-gap: 4px;  padding: 8px;  position: fixed;  position-area: right span-y-end;  position-try-fallbacks: --bottom;}

@position-try – 创建名为 –bottom 的规则。
锚点名称 – 将按钮设置为锚点元素。
position-anchor – 让菜单列表使用 –anchorbutton 作为锚元素。
position-try-fallbacks – 帮助列出要尝试的多个后备。这意味着即使 –bottom 失败,也可以有更多位置。

概括

anchor css 的出现为开发人员解决了一些非常有趣的用例。除了上述之外,系留定位变得非常容易。一切都纯粹基于 css,因此性能也很棒。 目前浏览器支持还不是很好,但我希望它很快就会被更多人采用。

以上就是CSS 新的 @position-try 的便利性的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
解决Flexbox六边形网格在窄屏溢出问题:响应式单位vw的应用
上一篇 2026年5月10日 10:36:53
为什么HTML input字段不能自动换行?以及如何实现多行文本输入
下一篇 2026年5月10日 10:36:55

相关推荐

  • Linux Zim Wiki嵌入,HTML+CSS语法高亮笔记!

    启用Zim Wiki的“代码块”插件并选择HTML/CSS语法模式可实现语法高亮,通过插入代码块、添加html或css标识符,并自定义CSS样式文件中的背景、字体和边框规则,提升代码可读性与视觉效果。 如果您在使用Zim Wiki记录技术笔记时,希望嵌入HTML和CSS代码并实现语法高亮显示,可以通…

    2026年5月10日
    000
  • 为什么HTML input字段不能自动换行?以及如何实现多行文本输入

    html 元素本质上是为单行文本输入设计的,不具备自动换行功能,也无法通过css或其他属性实现多行文本输入。当需要用户输入多行文本并支持自动换行时,必须使用 元素。本文将详细解释这两种元素的根本区别及其正确应用场景,帮助开发者选择合适的表单控件。 在网页开发中,我们经常需要从用户那里获取文本输入。H…

    2026年5月10日
    000
  • 解决Flexbox六边形网格在窄屏溢出问题:响应式单位vw的应用

    针对Flexbox六边形网格在窄屏设备上出现内容溢出的问题,本教程将深入探讨vh单位在宽度定义上的局限性。核心解决方案是改用vw(视口宽度)单位来定义六边形元素的宽度和水平边距,确保网格能根据视口宽度进行自适应缩放,从而有效避免溢出,实现完美的响应式布局。 理解窄屏溢出问题 在构建响应式布局时,尤其…

    2026年5月10日
    000
  • 解决XPath local-name() 语法错误:表达式无效

    本文旨在帮助开发者解决在使用 Python 进行网页抓取时,遇到的 XPath local-name() 函数导致的 SyntaxError: The expression is not a legal expression 错误。通过分析问题原因,提供正确的 XPath 语法,并给出更通用的解决方…

    2026年5月10日
    000
  • html滚动条样式怎么在safari生效_html滚动条Safari浏览器适配方法

    Safari桌面版支持-webkit-scrollbar自定义滚动条,需确保元素可滚动并使用::-webkit-scrollbar、track、thumb等伪元素设置样式,同时添加border:1px solid transparent等触发渲染;而移动端Safari不支持该特性,建议保持默认样式或…

    2026年5月10日
    000
  • 什么是javascript单页应用_与传统网页有何区别?

    JavaScript单页应用(SPA)仅用一个HTML页面,通过JavaScript动态更新内容,实现局部刷新;传统网页每次跳转都请求新HTML并整页重载。 JavaScript单页应用(SPA)是指整个网站只用一个HTML页面,所有内容切换和交互都由JavaScript在浏览器端动态完成,不触发整…

    2026年5月10日
    000
  • 如何用 HTML 和 CSS 实现一个可展开的圆盘,并让每个子圆盘都可独立触发事件?

    html、css实现圆盘(类环形图) 实现一个圆盘,单击后会在圆周围弹出分开的六个圆盘,每个圆盘可以独立触发事件。 实现方法: 可以使用 transform 属性来旋转和倾斜元素,从而实现圆盘展开的效果。 立即学习“前端免费学习笔记(深入)”; 步骤: 创建一个主圆盘:使用 div 元素并应用圆形样…

    2026年5月10日
    000
  • html5如何用li_html5使用li标签方法【标签用法】

    li标签必须嵌套在ol或ul内,不可直接置于body等非法父元素中;需闭合标签;可嵌套多层列表;不可在dl中使用li替代dt/dd。 如果您希望在HTML5中正确使用 标签来构建列表结构,则需要确保标签始终嵌套在有序列表或无序列表内部。以下是几种标准且兼容的使用方法: 一、在无序列表中使用li标签 …

    2026年5月10日
    500
  • 如何用css做form表单?css form表单制作的方法

    网页中的表单是用于搜集用户的输入,简而言之,就是表单是网页与用户交互的一个不可或缺的元素,也就是说表单是用于向服务器传输数据的,总而言之,表单在网页中是非常重要的,所以,接下来的这篇文章将给大家来介绍如何用css来制作一个form表单,话不多说,让我们来看一下用css做form表单的具体内容。 首先…

    2026年5月10日
    000
  • PHP SQL:在显示所有数据的同时更改过滤数据的样式

    本文档旨在解决在使用 PHP 和 SQL 查询数据库时,如何在网页上显示所有数据,并同时突出显示或改变特定过滤数据的样式的问题。我们将提供一种解决方案,该方案允许用户搜索特定 ID,并在显示所有记录的同时,突出显示匹配的记录。如果搜索的 ID 不存在,则显示“Record not found”消息。…

    2026年5月10日
    000
  • html如何插入本地图片 本地图片引用教程

    html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程html如何插入本地图片 本地图片引用教程

    要在html中插入本地图片,需正确使用标签并指定路径。1. 使用src属性指向图片文件,推荐使用相对路径以确保可移植性;2. 注意路径拼写、大小写及文件是否存在;3. 图片无法显示时检查路径、缓存、权限,并通过开发者工具查看请求状态码;4. 优化加载速度可通过压缩图片、选择合适格式、使用cdn、懒加…

    2026年5月10日 用户投稿
    000
  • JavaScript中高效移除指定CSS类名DOM元素的方法

    本教程详细探讨了在javascript中高效移除具有特定css类名的dom元素的方法。我们将介绍传统removechild方法的潜在复杂性,并重点推荐使用现代且简洁的element.prototype.remove()方法。通过具体的表格行移除示例,文章将指导读者如何利用该方法清空动态生成的ui组件…

    2026年5月10日
    000
  • 在Shopify主题中高效集成外部与内部JavaScript脚本

    本教程详细介绍了如何在shopify主题中直接注入自定义javascript脚本标签的两种核心方法。文章涵盖了通过liquid的`script_tag`过滤器引入外部url托管的脚本,以及将自定义js文件上传至主题资产并利用`asset_url`和`script_tag`过滤器进行引用的步骤。旨在提…

    2026年5月10日
    000
  • 如何在CSS中精确计算文本宽度,考虑大写和小写字母的差异?

    解决文本宽度计算问题 在css文本大小设置中,小写英文字符并不遵循所设定的字体大小,导致使用文本字数乘以字体大小无法准确获取文本宽度。本文旨在讨论如何解决这一问题。 匹配大写和小写英文字符 为了分别获得大写和小写英文字符的数量,可以使用正则表达式: 立即学习“前端免费学习笔记(深入)”; 大写英文:…

    2026年5月10日
    000
  • HTML5如何设置隐藏_HTML5元素隐藏属性设置【隐藏】

    HTML5元素隐藏有六种方法:一、hidden属性(移除渲染树);二、CSS display: none(不占布局);三、visibility: hidden(占位但不可见);四、opacity+transform(视觉隐藏且可交互);五、aria-hidden配合视觉隐藏类(兼顾无障碍);六、da…

    2026年5月10日
    100
  • 使用PHP和AJAX实现待办事项的无刷新删除

    本文详细介绍了如何利用PHP、MySQL和jQuery AJAX技术,实现待办事项列表的无刷新删除功能。通过客户端JavaScript发送异步请求到服务器端PHP脚本,PHP负责数据库操作,JavaScript则在成功后动态更新页面UI,从而提供流畅的用户体验,避免了页面整体刷新。 引言 在现代We…

    2026年5月10日
    000
  • Puppeteer自动化:处理动态密码键盘点击与XPath策略

    在使用puppeteer进行自动化测试时,处理动态密码键盘这类非标准输入组件常遇到点击失效问题,表现为`node is either not clickable or not an htmlelement`错误。本教程将详细介绍如何通过将密码拆分为字符、利用xpath精确匹配键盘按键,并结合shif…

    2026年5月10日
    000
  • 如何使用CSS更好地格式化HTML元素_CSS格式化HTML元素最佳实践

    使用语义化HTML和有意义的类名,2. 采用BEM命名法模块化CSS,3. 重置默认样式并统一基础设置,4. 利用Flexbox和Grid实现现代布局,5. 避免深层选择器以提升性能,6. 使用CSS自定义属性管理主题变量,7. 优先移动端进行响应式设计。 要让网页看起来整洁、专业,关键在于如何用C…

    2026年5月10日
    000
  • JavaScript实现表单提交前的确认与取消机制

    本文详细介绍了如何使用JavaScript为网页表单添加提交前的确认对话框。通过监听表单的submit事件,并在用户点击确认框中的“取消”按钮时,利用event.preventDefault()方法有效阻止表单的默认提交行为,从而提升用户操作的安全性与体验。 理解表单提交事件与确认机制 在网页开发中…

    2026年5月10日
    000
  • 在 Next.js 中循环渲染 Props 的正确方法

    在 Next.js 中循环渲染 Props 的正确方法在 Next.js 中循环渲染 Props 的正确方法在 Next.js 中循环渲染 Props 的正确方法在 Next.js 中循环渲染 Props 的正确方法

    本文旨在解决在 Next.js 应用中使用 forEach 循环渲染 props 时遇到的问题。核心在于理解 forEach 和 map 方法的区别,并掌握如何正确使用 map 方法生成 React 组件,从而实现循环渲染。通过修改原代码,将 forEach 替换为 map,可以有效地解决渲染问题,…

    2026年5月10日 用户投稿
    000

发表回复

登录后才能评论
关注微信