Integrate cytoscaope with hexo (整合cytoscape和hexo)
更新日期:
Introduction
Cytoscape.js is an open source graph theory visaulization library written in Javascript. This article guide you through the procedures of integrating the library with hexo. There are many ways to do so, this is only one of the methods. People tend to put the javascript files inside after_footer.ejs
, however, the article content is loaded before javascript files. If you want to write the script of drawing graphs JUST INSIDE the markdown file, you have to wait until the javascript files of is loaded.
Installation:
The following guideline is written based on the themes called pacman.
- Download the
js
file and thejs.map
file from the offical website - Put the
js
file and thejs.map
file inside thethemes/pacman/source/js
folder - Download the waitUntil function from here, create a file called
waitUntil.js
put it insidethemes/pacman/source/js
folder - Put the code inside
themes/pacman/layout/_partial/head.ejs
, which loadwaitUntil
function before the article content1
2
3<% if (page.cytoscape) { %>
<%- js('js/waitUntil.js') %>
<% } %> - Put the code inside
themes/pacman/layout/_partial/after_footer.ejs
1
2
3<% if (page.cytoscape) { %>
<%- js('js/cytoscape.js') %>
<% } %> - Add an attribute to the post:
cytoscape: true
- Put the following codes inside the markdown file. It draws the graph inside the container called
cy
after thecytoscape
andjquery
are loaded. Remember that you have to set the style of the container, otherwise the graph will be invisible.1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51<div id="cy" style="width: 700px; height: 700px; display: block;"></div>
<script>
function draw(){
var cy = cytoscape({
container: $("#cy"), // container to render in
elements: [ // list of graph elements to start with
{ // node a
data: { id: 'a' }
},
{ // node b
data: { id: 'b' }
},
{ // edge ab
data: { id: 'ab', source: 'a', target: 'b' }
}
],
style: [ // the stylesheet for the graph
{
selector: 'node',
style: {
'background-color': '#666',
'label': 'data(id)'
}
},
{
selector: 'edge',
style: {
'width': 3,
'line-color': '#ccc',
'target-arrow-color': '#ccc',
'target-arrow-shape': 'triangle'
}
}
],
layout: {
name: 'grid',
rows: 1
}
});
}
$waitUntil(function(){ return typeof(cytoscape) != "undefined" && typeof($) != "undefined"},
draw);
</script>