Skip to content

Better spacing between CJK & Latin characters in your webpage

License

Notifications You must be signed in to change notification settings

zhenalexfan/Zige.js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Zige 字格

JSDelivr Liscence MIT

Animated logo

在此用简体中文阅读更多上下文。

What is it

In typography, spacing adjustments are needed between characters, which is also called kerning. However, modern web browsers and operating systems fail to do it properly when CJK characters (漢字, ひらがな, カタカナ, etc.) and Latin letters are mixed together in a webpage. If this upsets you too and you agree that "the space bar is not a design tool", Zige enables you to have better spacing between CJK and Latin characters without changing the text content itself (i.e. not by adding any whitespace characters!) in your webpage, by just adding one line of code.


A blog post example before & after using Zige

How to use

  1. Add zige.min.js to the <head> tag of your webpage.
<script src="https://cdn.jsdelivr.net/gh/zhenalexfan/zige.js/release/zige.min.js"></script>
  1. If you’d like to apply Zige to the entire webpage, you’re done! If you only want to correct the spacing within some specific parent elements, add class="zige" to them. Applying it only on the elements that contain CJK characters could improve performance. Below is an example.
<div class="zige"> <!-- Zige is applied recursively to all the child elements in this div -->
    <p>ウィキペディア日本語版は<a>2001年</a>5月頃に発足したものの⋯⋯</p>
</div>
  1. If you hope to do more customization — like tailoring the size of the spacing (0.25em by default), the class name, etc. — read the Development section below.

Development

Edit the following variables in zige.js to make corresponding customizations.

Variable Name Comment
CLASS_NAME Class name (zige by default) on the root elements for which spacing is generated.
SPAN_ATTR_NAME Attribute name (zige-margin by default) used on the span elements wrapping the alphabet subcontext inside the CJK context.
DEFAULT_AUTO_MARGIN_SIZE Margin size (0.25em by default) of the alphabet subcontext inside the CJK context.
CJK_SCRIPT Regex to match all CJK ideographs. Might need to be extended for more special usages.
CJK_SYMBOL Regex to match all CJK symbols and punctuation marks, including general punctuation used in both CJK context and alphabet context. Might need to be extended for more special usages.
ALPHABET_SCRIPT Regex to match all Latin letters. Might need to be extended for more special usages.
ALPHABET_SYMBOL Regex to match all Latin punctuations, including general punctuations used in both CJK context and alphabet context. Might need to be extended for more special usages.

How Zige works

Zige wraps Latin subcontexts in CJK contexts with <span> tags and adds CSS margins to them.

This solution was inspired by answers under this Zhihu question that I have followed since around 2013, especially the answers from 钱争予 and 千鸟.

While I don't believe this is the ultimate solution to the kerning problem in typesetting characters from multiple writing systems (it should be solved by fonts and operating systems!), it could be a better solution on web for now.

If you think the matching rules can be improved for more different characters or have any issues, feel welcome to submit a pull request, create an issue or email me!

About

Better spacing between CJK & Latin characters in your webpage

Resources

License

Stars

Watchers

Forks

Packages

No packages published