flex元素顺序调整靠标准属性order,非\_order;其默认值为0,按值升序排列,相同时依HTML源码顺序;负值前置,不支持小数或单位,且不影响DOM结构与:nth-child()。
order,不是 _order
CSS 里没有 _order 这个属性,这是常见拼写错误或受某些预处理器/框架误导产生的写法。真正控制 flex 子项排列顺序的是标准属性 order,它只在 display: flex 或 display: inline-flex 的

order 的默认值和排序逻辑每个 flex 子项的 order 默认值是 0。浏览器按 order 值从小到大排列元素;值相同时,按 HTML 源码顺序(document order)保持原有位置。
order 接受任意整数(正、负、零),不支持小数或单位order: -1 会排在所有 order: 0 元素之前order 不影响 DOM 结构,也不触发重排以外的副作用(如不会影响 :nth-child() 选择器)直接在 flex 子元素上设置 order 即可,无需修改父容器。但要注意几个典型陷阱:
display: flex → order 完全无效float 或 position: absolute → 脱离 flex 流,order 失效order 时,别漏掉单位(它不是长度值,不能写 order: 2px)order 值依赖 JS 计算,可能造成水合不一致(hydration mismatch)/* HTML */ A B C/ CSS / .container { display: flex; }
b { order: -1; } / B 会显示在最前面 /
c { order: 1; } / C 会显示在最后 /
order
order 适合视觉顺序调整,但不适合语义或可访问性重排。屏幕阅读器仍按 DOM 顺序读取,所以:
aria-flowto 等辅助属性order 很方便;但若涉及 SEO 或内容权重变化,更推荐用媒体查询 + flex-direction: column 配合源码顺序优化order 值本身不会产生过渡效果(它不支持 CSS transition),需要配合 transform 或其他可动画属性来模拟位移真正要调顺序时,先确认是否只是视觉层需求——否则光靠 order 可能埋下可访问性或 SEO 隐患。