css实现元素竖向排列 --- writing-mode

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了css实现元素竖向排列 --- writing-mode相关的知识,希望对你有一定的参考价值。

参考技术A 在许多使用场景下,会有让列表内元素竖着排列,高度不够,纵向换行的需求。本文教你如何实现一个竖着的元素排列。

实现元素纵向排列主要靠 css 的 writing-mode 属性和 float 属性。

设置 writing-mode 值为 vertical-lr , 可以使所有子元素纵向排列。

此时发现里面的子元素仍旧是横向排列,但文字变纵向了
再加上 float: left; 让元素左排。

此时,元素已经变成纵向排列了,但由于未限制高度,元素将无限向下排列。同时子元素的文字排列方式也变成了纵向。
在给列表加一个高度。并重新设置子元素 writing-mode 属性便可解决

此时效果已经完成,但还有一个奇怪的问题

在添加到某个位置元素直接会跳到这列最后一个,不知这个问题为何会产生,但是在给子元素添加一个宽度后,bug 便神奇的好了。。

总结: writing-mode 是一个很长久的 css 属性了,新的值 vertical-lr 在大部分现代浏览器都已支持,在古老的 ie9 以下,也可用 lr 代替,所以这种实现方式是可兼容的。只是注意某些浏览器需要 --webkit- 或 --ms- 前缀。

writing-mode 属性 --MDN

js+css 圆形/环形 排列

参考技术A 项目需要做个环形的导航排列,网上找到一篇详细介绍原理的文章 javascript-按圆形排列DIV元素(一)---- 分析 ,然后尝试着把它实现了,效果图如下:

源码分享给大家哦,拿走不谢O(∩_∩)O

vue版本的根据项目需求做了些略微的修改

以上是关于css实现元素竖向排列 --- writing-mode的主要内容,如果未能解决你的问题,请参考以下文章

怎么CSS中6张图片横向一行排列 并且要求在下方添加滚动条

css 只写div右边的阴影怎么写?

WPF 中想将Slider设置成竖向的,该怎么设置?? 求高手~~~

ionic使用ion-scroll实现竖向侧边可滚动菜单栏

js+css 圆形/环形 排列

CSS定位机制之浮动定位float