美文网首页
关于文字排版和相关操作的总结

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

作者: 夜舞暗澜_3ea2 | 来源:发表于2018-07-08 18:55 被阅读0次

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

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开始语义化了之后,有些标签的含义发生了变化。

  • <strong>:表示文本十分重要,一般用粗体;
  • <b>:提醒注意(Bring Attention To),虽然一般浏览器依然把它显示为粗体,但是不要把它当成粗体。
  • <em>:着重元素 (<em>) 标记出需要用户着重阅读的内容, <em> 元素是可以嵌套的,嵌套层次越深,则其包含的内容被认定为越需要着重阅读。
  • <i>:用于表现因某些原因需要区分普通文本的一系列文本。例如技术术语、外文短语或是小说中人物的思想活动等,它的内容通常以斜体显示。(现在很多地方会把<i>解释为icon)
  • <blockquote>, <q>, <cite>:引用。块级引用、行内引用、引用( Citation)。引用标签也可以嵌套。cite可能会显示为斜体。

再次强调:不要将样式寄希望于标签,因为浏览器的默认样式可能不一样。如果真的懒,请使用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属性还有:

  • ::-webkit-scrollbar — 整个滚动条.
  • ::-webkit-scrollbar-button — 滚动条上的按钮 (上下箭头).
  • ::-webkit-scrollbar-thumb — 滚动条上的滚动滑块.
  • ::-webkit-scrollbar-track — 滚动条轨道.
  • ::-webkit-scrollbar-track-piece — 滚动条没有滑块的轨道部分.
  • ::-webkit-scrollbar-corner — 当同时有垂直滚动条和水平滚动条时交汇的部分.
  • ::-webkit-resizer — 某些元素的corner部分的部分样式(例:textarea的可拖动按钮).

参考资料:

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已弃用
// 这是一个实验中的功能

相关文章

网友评论

      本文标题:关于文字排版和相关操作的总结

      本文链接:https://www.haomeiwen.com/subject/fanouftx.html