空白符对HTML结构的影响与解决方案
何为空白符?
空白符: 空格、制表符、换行符
注意:浏览器在解析HTML时会把所有空白符合并成一个空格
空白符对HTML结构的影响
HTML5中<textarea>标签placeholder无法正确显示
不好的结构造成意外的结果:
标签换行了:
<!--文本域结束标签 换行导致placeholder无法正确表示-->
<textarea id="description" name="description" rows="5" cols="30" wrap="physical" placeholder="这是一个多行输入框,输入您的个人描述">
</textarea>
标签之间有空格:
<!--文本域标签之间有空格,导致placeholder无法正确表示-->
<textarea id="description" name="description" rows="5" cols="30" wrap="physical" placeholder="这是一个多行输入框,输入您的个人描述"> </textarea>
结果:一片空白

原因:因为表单区域中包含了空白符(空格、制表符、换行符),textarea内的空白符被认为是内容,阻止了占位符文本的显示。
正确的操作:
<!--文本域开始标签与结束标签紧挨着,placeholder正确表示-->
<textarea id="description" name="description" rows="5" cols="30" wrap="physical" placeholder="这是一个多行输入框,输入您的个人描述"></textarea>
结果:占位了!!!

inline-block的默认空白间距
默认情况下,inline-block元素之间大约有“4px”的间距(不同浏览器会有不同的大小)。
<ul>
<li>item1</li>
<li>item2</li>
<li>item3</li>
<li>item4</li>
<li>item5</li>
</ul>
*{
margin: 0;
padding: 0;
}
ul {
list-style: none outside none;
padding: 10px;
background: green;
text-align: center;
}
ul li {
display: inline-block;
*display: inline;
zoom: 1;
background: orange;
padding: 5px;
}

- 原因:标签之间的空白符造成的。
- 解决:此时可以通过改变HTML的结构,让上一个li的结束标签与下一个li开始相连,去除空白符。
<ul>
<li>item1</li
><li>item2</li
><li>item3</li
><li>item4</li
><li>item5</li>
</ul>

你可以点击这里狠狠尝试demo
当然,空白符也是字符,去除它们也可以通过CSS样式letter-spacing、word-spacing来设定。详情见:如何解决inline-block元素的空白间距
除了相邻之间的Inline-block的空白间距外,像下面这种情况,也会产生空白符
<div class="container">
<img class="img" src="data:images/mod.jpg" alt="">
</div>
.container {
background: #fc0d0d;
}
.img {
display: inline-block;
width: 100%;
}

- 结果:容器没有显式设置高度与宽度,但是总会比它的子元素img高出几个像素(图中小熊头像下面的红色部分)
- 解决:把img的display设为block或者上面介绍的方法去除空白符的影响。
存在于文本中的空白符
如下面的换行符,和空格。
<div>They can stay 72-hours
within the Shandong province after they have entered China via the Qingdao International Airport.</div>
结果:浏览器解析的时候只保留单词之间的空白符被合并为一个空格。
They can stay 72-hours within the Shandong province after they have entered China via the Qingdao International Airport.
可以通过CSS属性white-space对文本中的空白符进行处理
white-space:normal | pre | nowrap | pre-wrap | pre-line | inherit
normal: 合并空白符,允许自动换行
nowrap: 合并空白符,不允许自动换行
pre-line: 合并空白符(不包括换行符),允许自动换行
pre: 不合并空白符,不允许自动换行
pre-wrap: 不合并空白符,允许自动换行(在pre基础上,保留自动换行)
详情见:demo
补充一点:CSS3新增了两个换行属性word-wrap和word-break。
长文本段落换行:
在Firefox则没有 问题,我尝试用white-spacing属性合并空白符,但是还有有一个空格,如果存在换行的话。


我看了别人的网站,它这里也存在换行了,但是浏览器没有解析它的空格,也没有看到它的代码里有对p作特殊的处理。

所以只能像前面一样改变HTML结构,去除它的空格。但是把所有文本放在一行,得铺在美国去。。。
解决方案:WebStorm可以设置自动换行——File-setting-Editor-General-Soft wrap(勾选Use soft wrap in editor),虽然视觉上是换行,浏览器解析的时候是按同一行文本解析的,所以不会在浏览器上产生空格。


总结
- 一般把元素设为inline-block是为了与其他元素在同一行排列,又或是为了能够应用text-align这样的属性,如果没这些必要,又想要对元素显式设置宽高,就
直接设置display: block。
- 那什么时候适合用inline-block呢?
- float元素脱离了文档流,会对其周围的元素造成影响,而inline-block不会有这些问题。
- 想要通过设置父容器text-align:center让元素居中,这显然用浮动无法做到
- 使元素垂直居中,inline-block元素是沿着默认的基线对齐,可以通过vertical属性设置这个默认基线。
参考资料
- MDN:white-space
- 小火柴的蓝色理想:深入理解CSS中的空白符和换行
空白符对HTML结构的影响与解决方案的更多相关文章
- lvarchar类型对表结构变更影响
informix中lvarchar类型设计用于存储中度长度的字符数据(短的常用varchar类型.特别长的字符可用text类型).其默认长度2048byte,最大长度32739byte,是一种可变长度 ...
- 关于masm中OFFSET伪指令对结构的影响
在masm中,如果offset修饰全局变量,则他返回的是变量的相对于其所在段的偏移,并且offset不能修饰局部变量哦. 若offset修饰的是文字常量则将被忽略: VAL = 1000h mov e ...
- JSONModel对架构的影响及解决方案
越来越多的项目使用CocoaPods,使用CocoaPods很有可能会用过JSONModel. JSONModel是个很强大的库,只要根据JSON定义好对应的类并继承JSONModel,就可以把JSO ...
- MySQL 事务 是对数据进行操作,对结构没有影响,比如创建表、删除表,事务就不起作用
- Spring Boot 2.4版本前后的分组配置变化及对多环境配置结构的影响
前几天在<Spring Boot 2.4 对多环境配置的支持更改>一文中,给大家讲解了Spring Boot 2.4版本对多环境配置的配置变化.除此之外,还有一些其他配置变化,所以今天我们 ...
- 应用程序框架实战三十八:项目示例VS解决方案的创建(一)
进行项目开发的第一步,是创建出适合自己团队习惯的VS解决方案,虽然我已经提供了项目示例,但毕竟是我创建的,你直接使用可能并不合适,另外你如果尝试模仿重新创建该示例,中间可能碰到各种障碍,特别是项目间的 ...
- VS解决方案创建
示例VS解决方案的创建(一) 进行项目开发的第一步,是创建出适合自己团队习惯的VS解决方案,虽然我已经提供了项目示例,但毕竟是我创建的,你直接使用可能并不合适,另外你如果尝试模仿重新创建该示例,中 ...
- Windows结构化异常处理浅析
近期一直被一个问题所困扰,就是写出来的程序老是出现无故崩溃,有的地方自己知道可能有问题,但是有的地方又根本没办法知道有什么问题.更苦逼的事情是,我们的程序是需要7x24服务客户,虽然不需要实时精准零差 ...
- C 关于二叉查找树的回顾,并简述结构接口设计
前言 最经想改写C用的配置读取接口, 准备采用hash或二叉树提到原先用的链表,提高查找效率.就回顾一下二叉树,这里分享一下二叉查找树,代码很精简的, 适合学习运用二叉树查找. 需要基础 1.具备C ...
随机推荐
- NVIDIA Jetson TX2刷机
官方安装教程 JetPack下载 主机端环境准备 需要在PC端安装虚拟机,虚拟机中安装Ubuntu14.04系统. 按照上面的地址下载JetPack-L4T-3.1-linux-x64.run 主机端 ...
- Maven web项目(简单的表单提交) 搭建(eclipse)
我们将会搭建一个,基于Maven管理的,具有简单的表单提交功能的web项目,使用DAO--service--WEB三层结构,服务器使用Tomcat 1 项目基本结构的搭建 左上角File---> ...
- 如何实现java的四则运算
很多语言底层对四则运算都有内部封装, 我们还是要重复造下轮子,不为别的, 就是为了面试可以多装一分 b, 假设你已经了解了什么是二进制, 什么是异或, 什么是移位运算, 什么是与, 这些不懂就别硬上( ...
- Map.Entry使用详解
1.Map.Entry说明 Map是java中的接口,Map.Entry是Map的一个内部接口. Map提供了一些常用方法,如keySet().entrySet()等方法,keySet()方法返回值是 ...
- Protrator 官网和下载工具稍慢 , 但能使用. Angular CLI 内置 官方推荐 TS的 demo 不明显 , 而且依赖无法安装
npm uninstall -g protractor && cnpm install -g protractor && protractor --version 复 ...
- Python归纳 | WSGI协议
1.WSGI介绍 1.1什么是WSGI 1.2怎么实现WSGI 2.由Django框架分析WSGI 3.实际环境使用的wsgi服务器 4.WSGI服务器比较
- 浅谈Supermap iClient for JavaScript 弹窗类
地图作为信息的载体和呈现方式,是GIS的重要组成部分,它是一个浏览信息的窗口,在信息日益发达的今天 ,各种地图应用如雨后春笋一般出现在大众眼前,而不是像以往一样太过局限于专业的领域.而弹窗,是作为地图 ...
- 2019美国大学生数学建模竞赛B题(思路)
建模比赛已经过去三天了,但留校的十多天里,自己的收获与感受依然长存于心.下面的大致流程,很多并没有细化,下面很多情况都是在假设下进行的,比如假设飞机能够来回运送药品,运货无人机就只运货,在最大视距下侦 ...
- Robot Framework(Collections 库)
Collections 库 Collections 库同样为Robot Framework 标准类库,它所提供的关键字主要用于列表.索引.字典的处理. 在使用之前需要在测试套件(项目)中添加:
- Android捕捉图像后在SurfaceView上变形显示问题的处理
我们在Android中经常会使用SurfaceView编写自定义的摄像头,可是有的时候会经常会出现图像的变形,我们就会很郁闷的问这到底是为什么呢?其实这个最根本的原因是SurfaceView和PreV ...