浏览器对 HTML 渲染,一个很有趣的问题

2016-03-02 19:03:48 +08:00
 lyning

今天遇到一个有趣问题, 两段一模一样的代码, 第一段有缩进, 第二段没有(用 js 处理后 append 到 html 页面), 浏览器渲染出来的效果居然不一样, 用 chrome devlop tools 排查了很久才发现这个问题, 然后将第二段代码缩进之后就恢复正常了, 有没有遇到我这样的问题最终找到原因的?

2599 次点击
所在节点    前端优化
7 条回复
hupeng
2016-03-03 08:30:10 +08:00
居然不一样?本来就是不一样的。。。
lyning
2016-03-03 09:34:30 +08:00
@hupeng 一模一样的, 最后用 devlop tools 编辑 html 手动换行渲染效果就正常了
otakustay
2016-03-03 12:34:45 +08:00
缩进就是空格啊,空格是 TextNode 啊,所以 2 个页面是不一样的啊……
lyning
2016-03-03 12:57:35 +08:00
@otakustay 原来时这样子哒, 我用 js 在组装 html 的时候每一个 tr 或者 li 前面都加上\t 或者 \r ,然后就达到我想要的效果了
justjavac
2016-03-03 23:10:30 +08:00
为什么用“居然”?
lyning
2016-03-04 10:32:26 +08:00
@justjavac 因为之前代码都是做了缩进才来做样式的, 现在才知道缩进之后布局会发生细微的变化,就是因为每个容器和布局之后多了空格
lyning
2016-03-04 10:34:04 +08:00
@otakustay 太谢谢你了, 又学到东西了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/260598

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX