inline-block间距产生的原因,去除inline-block间距的方法?及这个问题未来可能的解决方向。

大家好,我是IT修真院深圳分院第3期的学员,一枚正直纯洁善良的前端程序员,今天给大家分享一下,修真院官网前端工程师深度思考中的知识点——inline-block间距产生的原因,去除inline-block间距的方法?及这个问题未来可能的解决方向。



一.背景介绍

1、inline-block到底是什么?

关于inline-block在display里的英文解释:

This value causes an

element to generate an inline-level block container. The inside of an

inline-block is formatted as a block box, and the element itself is

formatted as an atomic inline-level box.

大致意思就是:inline-block 后的元素创建了一个行级的块容器,该元素内部(内容)被格式化成一个块元素,同时元素本身则被格式化成一个行内元素。

一句话解释:它是一个格式化为行内元素的块容器。

兼具行内元素和块元素的特点。

2、inline-block为什么会有间距?

归根结底这是一个西文排版的问题。举一个很简单的例子:

I am very happy

南京市长江大桥欢迎您

英文有空格作为词分界,而中文则没有。(这背后延伸出一个中文分词的问题)

这个问题的原因可以上述到SGML(标准通用标记语言)和TeX(排版工具),它实际上是一个行内(inline)的问题,它由空格、换行或回车所产生空白符所致


二.知识剖析

既然知道问题产生的原因,解决方法就由此得出。

1、改变代码书写方式。

2、改变字符大小。

3、改变元素间距。


三.常见问题

常见去除inline-block间距的方法有哪些?

小姐姐镇楼



四.解决方案

方法1: 改变书写方式

方法2:font-size

方法3:使用margin负值

方法4:使用word-spacing或letter-spacing

这些方法在网上能查到很详细的说明,我就简略记录一下。

方法1:改变书写方式

元素间留白间距出现的原因就是标签段之间的空格,因此,去掉HTML中的空格,自然间距就消失了。



我们可以把inline-block元素写在同一行,这种方案是最直接的解决方案,但却也是最不靠谱的方案,存在很多不可控因素。 很多场景会让你崩溃:前后端协同;版本更迭;他人接手;自己忘了...,太多一不小心都可能让这个方案失效。

考虑到代码可读性,显然连成一行的写法是不可取的,我们可以进行改进,还有下面非人类的写法:


方法2:font-size

这个方法,基本上可以解决大部分浏览器下inline-block元素之间的间距。


方法3:使用margin负值

margin负值的大小与上下文的字体和文字大小相关,Arial字体的margin负值为-3像素,Tahoma和Verdana就是-4像素,而Geneva为-6像素。由于外部环境的不确定性,以及最后一个元素多出的父margin值等问题,这个方法不适合大规模使用。


方法4:使用word-spacing或letter-spacing

一个是字符间距(letter-spacing)一个是单词间距(word-spacing),大同小异。

letter-spacing子元素要设置letter-spacing为0,不然会继承父元素的值;使用word-spacing时,只需设置父元素word-spacing为合适值即可。

使用letter-spacing和word-spacing时,其在不同浏览器下效果不同。




五.编码实战



六.扩展思考

上面使用到的几种方法都存在一定的缺陷,怎样兼容尽可能多的浏览器?

在不同情况下选用不同的方法,font-size基本上可以解决大部分浏览器下inline-block元素之间的间距。或者可以同时写多种方法,这样就可以兼容不同浏览器

这个元素的属性很奇特,刚出现的时候用得却不多,因为当初它在IE上的兼容性不好


window7上运行的IE版本是IE8,微软已经在2015年终止了对Windows 7的主流支持,准备到2020年停止对window7的所有技术支持

现在全浏览器对inline-block兼容性都很好,CSS任务很多布局也是利用这个元素的特殊属性来布局。再加上CSS压缩成一行完全解决空白字符间距问题。有点得心应手的感觉。

但是自提出这个元素过去10多年,现在更是出现flex、Grid这类好用的排版布局方式。他们确实有一些兼容性问题。好消息是2017年9月27日CSS弹性盒子布局规范已处于最终征求意见稿阶段,各大浏览器也渐渐支持弹性盒子的所有功能。

相信各位在css任务中刚接触flex的时候惊为天人,以后它的应用会越来越多,连B/S的4.0版也要加入flex属性,这个蛋疼的应用问题会随着时间消失。

四种方法哪种更为实用呢?

全都不实用,第一种不方便书写,后几种会导致内容和格式的依赖性较强,违背内容与样式分离的要求。在实际布局中很少单纯用inline-block排版,经常和float、position、flex配合使用。

我暂时知道的实用方法是用代码压缩,原理是方法1的特性,将代码压缩到一行。工具有Uglify等。或者使用不产生额外空白节点或者支持空白控制的模板语言。比如Jade、Smarty({strip} | Smarty)等

这些方法都是在CSS控制空白字符压缩特性尚未得到普遍支持之前使用的。在网上搜索的信息都是2012年、2013年的内容。如果项目还要考虑兼容IE8以下或者奇奇怪怪浏览器的话,了解一下这个问题也未尝不可,至少遇到问题知道怎么找解决方法。



七.更多讨论



八.参考文献

参考一:张鑫旭-鑫空间-鑫生活http://www.zhangxinxu.com/wordpress/2012/04/inline-block-space-remove-%E5%8E%BB%E9%99%A4%E9%97%B4%E8%B7%9D/

参考二:inline-block元素间间隙产生及去除详解http://demo.doyoe.com/css/inline-block-space/

参考三:CSS Flexible Box Layout Module Level 1https://drafts.csswg.org/css-flexbox/

参考四:使用CSS弹性盒子https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_Flexible_Box_Layout/Using_CSS_flexible_boxes

参考五:有哪些好方法能处理 display: inline-block 元素之间出现的空格?https://www.zhihu.com/question/21468450

参考六:如何裁剪 CSS/JS 文件(使用 UglifyJS 和 UglifyCSS)http://wiki.jikexueyuan.com/project/symfony-cookbook/minify-cssjs.html

参考七:代码压缩UglifyJS ——解决了display:inline-block之间留白问题http://www.jianshu.com/p/ece740688a01




PPT连接:

PPT 

如果这篇文章对你有帮助,并且使你对修真院免费在线学习感兴趣,可以通过我的链接注册成员会,这会使我得到学分(兑换学时)延长学习时间:

邀请链接:http://www.jnshu.com/login/1/13374512

邀请码:13374512

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容