关于文字排版和相关操作的总结

2018-07-08  本文已影响0人  夜舞暗澜_3ea2

想到什么写什么的总结帖:

1. 段落首行空两格:text-indent: 2em;

这个属性直接写长度几乎所有现代浏览器都能支持,但是关键字就不一定了。
https://developer.mozilla.org/zh-CN/docs/Web/CSS/text-indent
https://caniuse.com/#search=text-indent

2. 首字大小:::first-letter { font-size: 130%; }

相似的伪元素还有:::first-line,可以改变第一行的文字效果。

3. 英文大小写:text-transform: uppercase;

https://developer.mozilla.org/zh-CN/docs/Web/CSS/text-transform
一般常用的就是uppercase | lowercase,另外none可以禁止改变大小写。

4. 段落之间空行:直接用margin-bottom。

5. 加粗和斜体:不要将样式寄希望于标签!建议老老实实用span+class,或者可以在css中加一句:

p b { font-weight: bolder; }
p i { font-style: italic; }

6. 关于语义化标签:

自从HTML5开始语义化了之后,有些标签的含义发生了变化。

再次强调:不要将样式寄希望于标签,因为浏览器的默认样式可能不一样。如果真的懒,请使用normalize.css。

7. 光标选中文字样式:还有一个伪类选择器叫做::selection

例如:

::selection { background: #009a61;color:#fff; }  
::-moz-selection { background: #009a61;color:#fff; }  
::-webkit-selection { background: #009a61;color:#fff; }

不过::selection只支持backgroundcolor这两个属性。原因很简单:如果每次选中文字都要引起回流和重绘,那浏览器的开销也太大了些。

8. 想要保留滚动行为但是不想显示滚动条?

webkit内核中还有个伪类-webkit-scrollbar,不过看前缀就知道仅支持webkit内核的浏览器。

/* 禁止显示滚动条,但不影响滚动行为 */
.container::-webkit-scrollbar {
  display: none;
}

类似的css属性还有:

参考资料:

IE还是放弃吧,早期IE的滚动条只能改颜色,IE10+用webkit属性也是可以的。

9. 禁止复制(伪)

  1. JS和HTML属性的方式:
<div
    onmousemove="\HideMenu()\"
    oncontextmenu="return false"
    ondragstart="return false"
    onselectstart="return false"
    onselect="document.selection.empty()"
    oncopy="document.selection.empty()"
    onbeforecopy="return false"
    onmouseup="document.selection.empty()"
  >
    <!-- 一些内容 -->
  </div>
  1. CSS属性:user-select
  user-select: none; 
// -webkit-user-select已弃用
// 这是一个实验中的功能
上一篇 下一篇

猜你喜欢

热点阅读