Here is and a screenshot I uploaded for you Ich habe meinen Beitrag, nach Ihren Ratschlägen in den Kommentaren, meine aktualisierte Version meines Codes. Ich schließe in/**/meinem ursprünglichen Beitrag für die Hilfe.Ich kann Dialog nicht schließen in JointJS
/*In jointJS I try using a `ui.dialog` to delete all my graph with the following code:
var dialog = new joint.ui.Dialog({
width: 400,
title: 'Create new process',
content: '<b>Cleanup current drawing?</b>',
closeButton: false,
buttons: [
{ action: 'ok', content: 'OK' },
{ action: 'cancel', content: 'CANCEL' }
]
});
dialog.on('action:ok', this.graph.clear, this.graph);
dialog.on('action:cancel', dialog.close, dialog);
dialog.open();
},
After pressing OK button I successfully delete my graph but my dialog still remains without being able to delete it.
Any help please? */
Hier ist mein aktualisierter Code, der leider immer noch nicht wie erwartet funktioniert. Ich erinnere Sie daran, dass in dieser Dialogform, die ein OK zeigt und Abbrechen-Taste I die folgenden ein mag:
1) Wenn die OK-Taste Ich mag: a) Löschen meine aktuellen Graphen Und b) Schließen Sie meinen Dialog
2) Wenn auf Abbrechen ich möchte: meinen Dialog schließen (was in meiner ersten Version successfylly mit dialog.close
arbeitete)
openNew: function() {
// By pressing Create New Process button, a popup form asks for
//our confirmation before deleting current graph
var dialog = new joint.ui.Dialog({
width: 400,
title: 'Create new process',
content: '<b>Cleanup current drawing?</b>',
closeButton: false,
buttons: [
{ action: 'ok', content: 'OK' },
{ action: 'cancel', content: 'CANCEL' }
]
});
//Since in 'action:ok' of dialog.on the 3rd parameter is used in the
//callback of multi_hand we must pass dialog and graph both together.To do so
//we enclose them in an object named together and we pass it instead
together= {dialog : dialog, graph : this.graph};
//Since jointJS supports assigning multiple events for same handler
//BUT NOT multiple handlers for the same event we create function multi_hand
multi_hand: function (together)
{
together.graph.clear();
together.dialog.close();
}
dialog.on('action:ok', multi_hand, together);
dialog.on('action:cancel', dialog.close, dialog);
dialog.open();
},
diesen neuen Code mit meinem joinjtJS Projekt unerwartet abstürzt. Wie mache ich bitte OK-Taste?
Ich habe meinen Beitrag aktualisiert.Bitte überprüfen Sie es. –
Probieren Sie 'console.log (this.graph)' irgendwo im 'openNew'-Funktionskörper. Es sollte nicht 'undefiniert' sein. –
Ich habe mein Problem auf diese Weise gelöst und möchte es nur mit euch allen als Referenz teilen. –