您现在的位置是:网站首页> 编程资料编程资料
谈自适应宽度 _CSS教程_CSS_网页制作_
2021-09-07
877人已围观
简介 最近控件设计中涉及到换行处理,之前有三篇是当时过程中的换行处理方法,需求是不能换行,在内容超长时出滚动条
大概需求和情况是这样的.今天提交的代码自我感觉是比较好的一版了,代码质量和个人编程知识/经验等紧密相关,不求最好,但求better and better.在这里做一个总结文,基于之前《换行情况处理》、《又谈换行情况处理》、《换行情况处理之三》及没来得及记录的经验。
当内容超出父级元素宽度,在未设置white-space:nowrap时会自动换行,设置了white-space:nowrap样式又不能关联到滚动条延伸的部分,解决方案如下:
1、在父级元素添加white-space:nowrap属性;
2、计算(每一行)内容宽度;
a、将内容拆分,包括缩进、图片和文字。
b、利用《又谈换行情况处理》中在body末尾添加非换行dom元素计算文字宽度。
c、叠加拆分的小块宽度为总宽度。
3、去掉父级元素的white-space:nowrap属性;
4、取2中最大宽度,设置成父级元素的宽度(最好在该精确宽度的基础上增加6px-8px的宽度预留给滚动条,一是满足滚动条出现,二是也不会贴边)。
该方法优点(与之前几种方案相比):
1、宽度计算准确。
2、性能稳定,没有之前循环“试探”的过程,遍历一遍节点即可完成。
What's more, 工作总是在种种业务场景之下的,像上面解决的这个问题就是。
当内容超出父级元素宽度,在未设置white-space:nowrap时会自动换行,设置了white-space:nowrap样式又不能关联到滚动条延伸的部分,解决方案如下:
1、在父级元素添加white-space:nowrap属性;
2、计算(每一行)内容宽度;
a、将内容拆分,包括缩进、图片和文字。
b、利用《又谈换行情况处理》中在body末尾添加非换行dom元素计算文字宽度。
c、叠加拆分的小块宽度为总宽度。
3、去掉父级元素的white-space:nowrap属性;
4、取2中最大宽度,设置成父级元素的宽度(最好在该精确宽度的基础上增加6px-8px的宽度预留给滚动条,一是满足滚动条出现,二是也不会贴边)。
该方法优点(与之前几种方案相比):
1、宽度计算准确。
2、性能稳定,没有之前循环“试探”的过程,遍历一遍节点即可完成。
What's more, 工作总是在种种业务场景之下的,像上面解决的这个问题就是。
相关内容
- CSS圆角效果 -webkit-border-radius(CSS3中border-radius隐藏的威力)_CSS教程_CSS_网页制作_
- 怎么去掉form的高度(form不会撑出td)_CSS教程_CSS_网页制作_
- css中强制换行word-break、word-wrap、white-space区别实例说明_CSS教程_CSS_网页制作_
- 牛人也得看的15个CSS技巧(提高网页效率)_CSS教程_CSS_网页制作_
- IE6的inline-block _CSS_网页制作_
- 只用CSS美化选择框的实现代码_CSS教程_CSS_网页制作_
- 同一html页面中不同链接的不同样式的css代码_CSS教程_CSS_网页制作_
- CSS外边距合并代码_CSS教程_CSS_网页制作_
- DIV水平垂直居中css实现代码 _CSS布局实例_CSS_网页制作_
- 网页设计中input标签写CSS时需要注意的几个问题 _Div+CSS教程_CSS_网页制作_