Я хотел бы структурировать этот код в лучшем виде, создав какие-то модули. Я использую ES6, поэтому я попытался использовать import
/export
.JS: Функция разделения в виде частей модуля
Пример функции
function() {
var graph = new joint.dia.Graph;
var paper = new joint.dia.Paper({
el: $('#canvas'),
width: 600,
height: 200,
model: graph,
gridSize: 1
});
var rect = new joint.shapes.basic.Rect({
position: { x: 100, y: 30 },
size: { width: 100, height: 30 },
attrs: { rect: { fill: 'blue' }, text: { text: 'my box', fill: 'white' } }
});
var rect2 = rect.clone();
rect2.translate(300);
var link = new joint.dia.Link({
source: { id: rect.id },
target: { id: rect2.id }
});
graph.addCells([rect, rect2, link]);
}
Так что я хотел бы получить что-то подобное, что было бы гораздо лучше читаемым:
script.js
import * from './config.js';
function() {
var graph = graph();
var paper = paper();
var rect = rect();
var rect2 = rect.clone();
rect2.translate(300);
var link = link();
graph.addCells([rect, rect2, link]);
}
И все содержимое должно быть в другом файле:
config.js
export
var graph = new joint.dia.Graph,
var paper = new joint.dia.Paper({
el: $('#canvas'),
width: 600,
height: 200,
model: graph,
gridSize: 1
});
// ...
Но эта попытка не имеет правильный синтаксис. Как это сделать?