素肌にサスペンダー

個人的な備忘と日記

JavaScriptで、文字列の中からURLを検知してリンクにする

フロントエンドで、文字列の中からURLの部分を検知して、自動的にaタグのリンクを生成する方法をメモ。

こちらの記事の内容で出来た。 ginpei.hatenablog.com

サンプル

テキストエリアに、URLを含んだ文字列を入力して送信すると、aタグに変換されたhtmlがdiv#js-resultに反映される。

※ただし、2バイト文字を含んだURLだとうまくいかない。また、URLに続けて半角英数字などを入れるとそれも含んでURLと判定されるので、入力フォームに注釈入れるなど配慮が必要。

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>

<form action="" onsubmit="return false">
<textarea name="" id="js-text" cols="30" rows="10"></textarea>
<input type="submit" name="" id="" onclick="AutoLink()">
</form>

<p>↓結果</p>
<div id="js-result"></div>

<script>
function AutoLink() {
var str = document.getElementById('js-text').value
var regexp_url = /((h?)(ttps?:\/\/[a-zA-Z0-9.\-_@:/~?%&;=+#',()*!]+))/g; // ']))/;正規表現(/〜/)を解釈してくれないエディタ等で自動整形を崩さないため。
var regexp_makeLink = function(all, url, h, href) {
return '<a href="h' + href + '" target="_blank">' + url + '</a>';
}
var textWithLink = str.replace(regexp_url, regexp_makeLink);
document.getElementById('js-result').innerHTML = textWithLink
}
</script>
</body>
</html>