jQuery: durch Drupal Behaviors Fehlverhalten auf Seite
am 24.02.2012 - 10:17 Uhr in
Hallo,
ich habe ein Problem mit den Drupal Behaviors, welche ein komisches Verhalten auf meiner Seite auslösen. Komisch in dem Sinne, dass nach erstmaligem Ausführen von Drupal.attachBehaviors die 2 Dialoge der Seite nochmals geladen werden, sodass sich insgesamt 4 Dialoge auf der Seite befinden. Jedoch benötige ich nur 2, wie beim ersten Betreten der Seite. Des Weiteren lässt sich nach diesem erstmaligem Ausführen, und damit dem ersten hinzugefügten Datensatz über das Eingabeformular des Dialogs, kein weiterer Datensatz hinzufügen. Der Dialog kann ein zweites und drittes, viertes... mal geöffnet werden, aber bei Klick auf OK passiet einfach nichts.
Der Quelltext sieht folgendermaßen aus (gekürzt):
// $Id: add_rde_server.js $
(function ($) {
Drupal.behaviors.add_rde_server = function (context) {
var $counter = 0;
// Aufbau des Eingabeformulars im erscheinenden Dialog
var $add_form = '<form>'+
'<p class="add_form"><b>Name: </b><br /><input type="text" id="bezeichnung_rde_server" name="name" size="30" maxlength="50" /></p>'+
'<p class="add_form"><b>Beschreibung: </b><br /><textarea id="beschreibung_rde_server" name="beschreibung" rows="10" cols="100" /></p>'+
'</form>';
// Tabelle, welche den erstellten Inhalt anzeigt
var $contentTable = '<p><table id="rde_server" class="ui-widget ui-widget-content">'+
'<thead>'+
'<tr class="ui-widget-header">'+
'<th>Name</th>'+
'<th>Beschreibung</th>'+
'<th></th>'+
'</tr>'+
'</thead>'+
'<tbody>'+
'</tbody>'+
'</table></p>';
$('#contentBlock_rde_server:not(.add_rde_server-processed)', context).append($contentTable).addClass('add_rde_server-processed');
// Eigenschaften der Dialogfenster und Bestimmung der Funktionsweise beim Betätigen der Buttons
var $add_dialog = $('<div></div>').html($add_form).dialog({
modal: true,
width: 750,
height: 450,
title: 'RDE-Server erstellen',
autoOpen: false,
buttons: {
'OK': function () {
var $value_exists = new Boolean();
$value_exists = validateAndSubmit();
if ($value_exists) {
$(this).dialog('close');
clearForm();
}
else {
$('#bezeichnung_rde_server').attr('style', 'border-color: red;');
}
},
'Close': function () {
$(this).dialog('close');
clearForm();
}
}
});
// Aufruf des Hinzufügen-Dialogs beim Klick auf Link der Klasse add-rde-server-dialog
$('.add-rde-server-dialog', context).click(function () {
$add_dialog.dialog('open');
return false;
});
function validateAndSubmit () {
var $val = new Boolean();
$val = validate();
if ($val == true) {
appendContent();
$counter++;
return true;
}
else if ($val == false) {
return false;
}
}
function validate () {
var $name = $('#bezeichnung_rde_server').val();
var $value_exists = new Boolean();
if ($name == "") {
$('#bezeichnung_rde_server').after('<b id="warning" style="color: red; font-size: 8pt;">Bitte geben Sie eine Bezeichnung für den RDE-Server ein</b>');
return false;
}
$.ajax ({
type: 'get',
url: '/drupal/sites/all/modules/custom/add_rde_server/existingValue.php?name='+$name,
dataType: 'json',
async: false,
success: function ($reqCode) {
if ($reqCode.msg == 'failed') {
$('#bezeichnung_rde_server').after('<b id="warning" style="color: red; font-size: 8pt;">Ein RDE-Server mit diesem Namen existiert bereits</b>');
$value_exists = false;
}
else if ($reqCode.msg == 'success') {
$value_exists = true;
}
}
});
return $value_exists;
// var $regex = /^\w[\w|\.|\-]+/g;
}
function appendContent () {
var $name = $('#bezeichnung_rde_server').val();
var $descr = $('#beschreibung_rde_server').val();
var $append = $('#rde_server tbody', context).append('<tr>'+
'<td id="rde_server_'+$counter+'">'+$name+'</td>'+
'<td id="descr_rde_server_'+$counter+'">'+$descr+'</td>'+
'<td><a class="edit-rde-server-dialog" id="edit-rde-server-'+$counter+'" href="/drupal/add-rde-server-mainpage/edit-rde-server-dialog">Bearbeiten</a></td>'+
'</tr>'
);
// nur den Block $append anhängen, scheint aber nicht wie gewünscht zu funktionieren
Drupal.attachBehaviors($append);
}
}
})(jQuery);
Vielen Dank schonmal.
MfG
EDIT: Ist natürlich die quasi-Fortsetzung des Threads http://www.drupalcenter.de/node/39933, ich wusste nicht so recht ob einen neuen Aufmachen oder nicht. ;D
- Anmelden oder Registrieren um Kommentare zu schreiben
Neue Kommentare
vor 3 Tagen 2 Stunden
vor 3 Tagen 10 Stunden
vor 3 Tagen 14 Stunden
vor 3 Tagen 19 Stunden
vor 1 Woche 11 Stunden
vor 1 Woche 13 Stunden
vor 1 Woche 1 Tag
vor 2 Wochen 3 Tagen
vor 3 Wochen 5 Tagen
vor 4 Wochen 23 Stunden