2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

URL を自動リンクさせずに表示させたい

Last updated at Posted at 2022-11-20

URL を自動リンクさせずに表示させたい

例えば、以下のような URL をそのままにすると、自動的にリンクが作成される。これは、< ~ > を省略する拡張となっている。

https://www.example.com

Qiita では、このような生のリンクをリンクカードとして表示させている。

本記事では、これらの自動リンクを無効化して、そのまま文字列が表示する方法を考えたい。

ちなみに、行内コードやコードブロックを利用すれば、もっとも簡単に文字列のみ表示させることが出来る。しかし、背景色が変わってしまったり、本文中に挿入できない。今回はこれを求めているわけではない。(どこに利用価値があるのかと問われると、あっ…)

■ GFM による仕様

生のリンクを自動的にリンクとして認識させる仕様は GFM に記載されている。

§ 6.9 Autolinks (extension) - GitHub Flavored Markdown Spec

この仕様を確認すると、URI スキームから始まるフルの URL (1.)、www から始まる URI スキームが省略されている URL (2.)、電子メール (3.) の 3 種類が自動的にリンクとして解釈される。

1. https://www.example.com
1. www.example.com
1. example@email.com
  1. https://www.example.com
  2. www.example.com
  3. example@email.com

■ URL の自動リンクの回避

フルの URL と www から始まる省略された URL は、ともに www が解析に関して重要な部分になるようだ。そのため、www を強調させるとリンクとして機能しなくなる。

- https://*www*.example.com
- *www*.example.com
  • https://www.example.com
  • www.example.com

この場合、www だけが斜体になってしまい、自動リンクは回避しているもののそのまま表示させているとは言えない。

ダミーの HTML タグを使って回避させることが出来る。この場合では、斜体など文字に装飾が加わらない。

- https://<foo>www</foo>.example.com
- <foo>www</foo>.example.com
  • https://www.example.com
  • www.example.com

ただし、HTML タグが許されている場合に限られることには注意が必要になる。(e.g. Dellinger.io では HTML タグが使えない)

■ 電子メールの自動リンクの回避

電子メールの場合も同様に、強調や HTML タグを利用すると自動リンクを回避することが出来る。

- *example*@email.com
- <foo>example</foo>@email.com
  • example@email.com
  • example@email.com

ただし、電子メールであれば、@AT-at- と表記しておいて、読み手に @ へ修正させる方法が主流なような気もする。

■ CommonMark に準拠する場合

CommonMark に準拠する場合、HTML ブロック内の Markdown はリテラルに解釈される。そのため、<p></p><div></div> などの HTML タグで HTML ブロック内に URL や電子メールを含めれば良い。

- <div> https://www.example.com </div>
- <div> www.example.com </div>
- <div> example@email.com </div>
  • https://www.example.com
  • www.example.com
  • example@email.com

ただし、この方法では一部の Markdown 記法内の URL や電子メールの自動リンクを回避することが出来ない。また、HTML ブロックの仕様をある程度理解している必要がある。

■ 番外編

パーサによって結果に差が生じる方法。

▽ ゼロ幅スペースを挿入する

HTML エンティティを利用して行頭にゼロ幅スペースを挿入することで自動リンクを回避することも出来る。

- &#8203;https://www.example.com
- &#8203;www.example.com
- &#8203;example@email.com

ただし、コピーするとゼロ幅スペースも意図せず含まれる場合があるため、少し注意が必要になる。

▽ 特定の文字をエスケープする

特定の文字をエスケープすると自動リンクを回避することが出来る。以下のように、:www の後ろの . をエスケープする。

- https\://www.example.com
- www\.example.com
  • https://www.example.com
  • www.example.com

電子メールの場合は、どの文字をエスケープしても上手くいかないようだ。

余談

強調を利用して自動リンクを回避する場合、一部だけが強調され不自然になる。これを少しでも綺麗にするには、全体を強調すれば良い。

- *https://*www*.example.com*
- **www*.example.com*
- **example*@email.com*
  • https://www.example.com
  • www.example.com
  • example@email.com

また、ダミーの HTML タグを利用している場合、<samp> タグで全体を覆うと等幅フォントになる。

- <samp>https://<foo>www</foo>.example.com</samp>
- <samp><foo>www</foo>.example.com</samp>
- <samp><foo>example</foo>@email.com</samp>
  • https://www.example.com
  • www.example.com
  • example@email.com

この記事を読んで「役に立った!」と感じる人はどれくらいいるのだろう :thinking:

追記

2023/01/26: CommonMark によるリンクの回避方法を追記

2
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?