Bokeh - Développement avec JavaScript

La bibliothèque Bokeh Python et les bibliothèques pour d'autres langages tels que R, Scala et Julia interagissent principalement avec BokehJS à un niveau élevé. Un programmeur Python n'a pas à se soucier du développement JavaScript ou Web. Cependant, on peut utiliser l'API BokehJS, pour faire du développement JavaScript pur en utilisant directement BokehJS.

Les objets BokehJS tels que les glyphes et les widgets sont construits plus ou moins de la même manière que dans l'API Bokeh Python. En règle générale, tout nom de classe Python est disponible sous la formeBokeh.ClassNameà partir de JavaScript. Par exemple, un objet Range1d obtenu en Python.

xrange = Range1d(start=-0.5, end=20.5)

Il est obtenu de manière équivalente avec BokehJS comme -

var xrange = new Bokeh.Range1d({ start: -0.5, end: 20.5 });

Suivre le code JavaScript lorsqu'il est incorporé dans un fichier HTML restitue un tracé linéaire simple dans le navigateur.

Incluez d'abord toutes les bibliothèques BokehJS dans la section <head> .. </head> de la page Web comme ci-dessous

<head>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-widgets-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-tables-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-gl-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-api-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-api-1.3.4.min.js"></script>
</head>

Dans la section du corps, les extraits de code JavaScript suivants construisent diverses parties d'un tracé bokeh.

<script>
// create some data and a ColumnDataSource
var x = Bokeh.LinAlg.linspace(-0.5, 20.5, 10);
var y = x.map(function (v) { return v * 0.5 + 3.0; });
var source = new Bokeh.ColumnDataSource({ data: { x: x, y: y } });
// make the plot
var plot = new Bokeh.Plot({
   title: "BokehJS Plot",
   plot_width: 400,
   plot_height: 400
});

// add axes to the plot
var xaxis = new Bokeh.LinearAxis({ axis_line_color: null });
var yaxis = new Bokeh.LinearAxis({ axis_line_color: null });
plot.add_layout(xaxis, "below");
plot.add_layout(yaxis, "left");

// add a Line glyph
var line = new Bokeh.Line({
   x: { field: "x" },
   y: { field: "y" },
   line_color: "#666699",
   line_width: 2
});
plot.add_glyph(line, source);

Bokeh.Plotting.show(plot);
</script>

Enregistrez le code ci-dessus en tant que page Web et ouvrez-le dans le navigateur de votre choix.