CSS 排版

记录 CSS 排版方面犯的各种强迫症,希望各浏览器加大力度。

中英混排

如果网页上中英文使用不同字体,CSS 声明里英文必须写在前面,然后英文字体就会把中文里的部分标点符号如引号等展示成半角状态。某乎这样对此强迫症的改用直角引号了。

但直角引号真的好麻烦鹅且我对其也有强迫症……

搜了一下发现其实可以用 @font-faceunicode-range 抽出中文字体。

@font-face {
  font-family: "CnSymbol";
  src: local("PingFang SC"), local("Sarasa Gothic SC"), local("Source Han Sans SC"), local("Noto Sans SC");
  unicode-range: U+00B7, U+2018-2019, U+201C-201D;
}

需要注意 -apple-system 不能用在缩写式 font 开头,会被误认为变量。好像改了。

SymbolUnicode
·U+00B7
U+2018
U+2019
U+201C
U+201D

标点挤压

暂时采取的方案:

function typesetting(el = document.querySelector("article")) {
  el.innerHTML = el.innerHTML
    .replace(/([”’」』》)】])([,。!?;:“”‘’()「」『』《》【】\s])/g, `<span class="type-punctuation">$1</span>$2`)
    .replace(/([,。!?;:“”‘’()「」『』《》【】])([“‘「『《(【])/g, `$1<span class="type-punctuation">$2</span>`);
}
.type-punctuation {
  font-feature-settings: "halt";
}