Mermaid.jsで制作したフローチャートのノードをクリックしてJavaScriptの関数を呼び出したい
Q&A
Closed
解決したいこと
Mermaid.jsを使ったフローチャートのノードをクリックして、JavaScriptで記述する処理を実行できるようにしたいと考えています。
- フローチャートのjsライブラリを探していたところ、Mermaid.jsが無料で使えるということで使ってみました。
- styleなどで見た目を変化させることはできました。また、callbackやhrefで文字を出現させたり、別のWebサイトに飛べたりすることも確認できました。
しかし、
ノードをクリックしてjavascriptに記述した関数を実行するということができていません。
よろしくお願い致します。
サンプルhtmlファイル
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="https://unpkg.com/mermaid/dist/mermaid.min.css">
<script src="https://unpkg.com/mermaid/dist/mermaid.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<title>Document</title>
</head>
<body>
<div class="mermaid">
graph TD
A-->B
A-->C
B-->D
B-->E
E-->F
F-->G
click A href "javascript:callback();"
</div>
<script>
// javascript の処理
function callback(){
alert('clickされました');
}
</script>
</body>
</html>
現状
クリックしても何も起きない
自分で試したこと
hrefをcallbackやonに置換すると、文字としてグラフの下部に出力されます。
どのように記述すればいいのか、はたまた不可能なのかわからない状態です。
0