Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Module › Modul-Entwicklung ›

Unterschied zwischen Drupal.behaviors und $(document).ready(function()

Eingetragen von Apfel007 (143)
am 15.04.2010 - 14:03 Uhr in
  • Modul-Entwicklung
  • Drupal 6.x

Hallo zusammen,
kann mir jemand sagen, ob es funktionell einen Unterschied zwischen Drupal.behaviors und $(document).ready(function() gibt?

Mein Problem besteht darin, das ich per JQuery, "views gallery Imageflow ", beibringen will, den Node des Bildes in einem Popup zu zeigen. Jquery setzt hier korrekt alle Klassen an ALLE BILDER! Alles korrekt geöffnet, nur der Iframe zeigt immer noch kurz den vorherigen Node an (irgendein Cache??) und wechselt dann zum neuen Node.

// jquery simple modale
function loadiframe(url){
  $.modal('<iframe src="' + url + '" height="800" width="600" scrolling="no">', {
    containerCss:{
backgroundColor:"#fff",
borderColor:"#fff"
},
overlayClose:true,
opacity:70,
overlayCss: {
    backgroundColor:"#000"
},
onOpen: function (dialog) {
dialog.overlay.fadeIn('slow', function () {
    dialog.container.toggleClass("preloader");
    dialog.data.hide();
dialog.container.fadeIn('slow', function () {
  dialog.container.toggleClass("preloader");
  dialog.data.slideDown('slow');
    });
    });
    },
    onClose: function (dialog) {
dialog.data.fadeOut('slow', function () {
dialog.container.slideUp('slow', function () {
dialog.overlay.fadeOut('slow', function () {
$.modal.close(); // must call this!
});
});
  });
    }
  });
}

$(document).ready(function(){
  $(".imagefield-field_gallery_image").click(function(){
  //var baseurl = location.host;
  var url = $(this).attr("target");
  var url = 'https://domain.de' + url;
  loadiframe(url);
  });
});

Wenn ich nun so etwas Versuche, um das Module Modalframe zum Leben zu erwecken, setzt JQuery auf alle Bilder das "link" Attribut vom 1. Bild. Woran liegt das? Habe hier schonmit dem livequery plugin was versucht, das in d6 das Jquery "live-plugin" nicht verfügbar ist.. Kann es hier daran liegen, das die Galerie dynamisch zusammen gestellt wird und das die Jquery-Funktion zum falschen Zeitpunkt aufgerufen wird? Nun zu meiner eigentlichen Frage - im ersten Beispiel werden die Click-Links richtig " verteilt, und im 2. wird nur der erste Click-Link verteilt. Heißt das nun das Drupal.behaviors und $(document).ready(function() unterschiedlich ausgeführt werden? Freue mich auf Hinweise!

// $Id: modalframe_example.js,v 1.1.2.7 2009/12/28 02:21:20  Exp $

(function ($) {
Drupal.behaviors.modalFrameExample = function(context) {
  //$('.imagefield-field_gallery_image:not(.modalframe-example-processed)').addClass('modalframe-example-processed').each(function () {
  $("img.imagefield-field_gallery_image:not(.modalframe-example-processed)")
    .addClass("modalframe-example-processed").each(function() {
    //$(this).livequery("click", function(event) {
      $(this).click(function(event) {
       var url = $(this).attr("link");
     Drupal.modalFrame.open({url: url, width: 800, height: 600});
     return false;
  });  });};
})(jQuery);

‹ Button Funktion Drupal [gelöst] Anfängerproblem: Link in einem Block erscheinen lassen ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Drupal.behaviors

Eingetragen von stBorchert (6003)
am 18.04.2010 - 18:02 Uhr

Hallo.
Erstmal der obligatorische Link zum Handbuch.
Drupal.behaviors reagiert nicht anders als $(document).ready(), da es vom Prinzip her etwas ganz anderes ist (nämlich eigentlich nur ein gewöhnliches jQuery-Objekt).
Dieses Objekt (im eigentlichen Sinne ein Attribut des Attributs "behaviors" des Objektes "Drupal") wird nach dem vollständigen Laden des DOM durch $(document).ready( ... ) ausgeführt.

Was passiert, wenn Du diesen Code hier verwendest?

Drupal.behaviors.modalFrameExample = function(context) {
  $('.imagefield-field_gallery_image:not(.modalframe-example-processed)').addClass('modalframe-example-processed').click(function(event) {
    Drupal.modalFrame.open({url: $(this).attr("link"), width: 800, height: 600});
    return false;
  });
};

hth,

 Stefan

  • Anmelden oder Registrieren um Kommentare zu schreiben

Moin Stefan, danke für die

Eingetragen von Apfel007 (143)
am 22.04.2010 - 14:34 Uhr

Moin Stefan,
danke für die Antwort.. ich konnte das Problem eingrenzen..das Problem war offensichtlich die dynamische Erzeugung der Galerie.. mit dem JQuery Plugin "livequery" funktioniert es.
Einziger Harken ist im Moment noch die "onSubmit" Funktion. Wie kann man die Serverseitige Funktion "modalframe_close_dialog()" aufrufen? Oder braucht man diese gar nicht und man könnte das ganze mit JS schließen? Was meinst Du?

(function ($) {
Drupal.behaviors.modalGalleryComment = function() {
  $('.imagefield-field_gallery_image').addClass('modalframe-gallery-comment-processed').livequery('click', function(event) {
    var element = this;
    // This is our onSubmit callback that will be called from the child window
    // when it is requested by a call to modalframe_close_dialog() performed
    // from server-side submit handlers.  TODO DON'T WORK!!!
    function onSubmitCallback(args, statusMessages) {
      // Display status messages generated during submit processing.
      if (statusMessages) {
        $('.modal-gallery-comment-messages').hide().html(statusMessages).show('slow');
      }

      if (args && args.message) {
        // Provide a simple feedback alert deferred a little.
        setTimeout(function() { alert(args.message); }, 500);
      }
    }
// TODO DON'T WORK!!!
    function onLoadAction(){
    $('#modalframe-container').remove($(this).css('background'));
    $('.ui-dialog-title').text();
    }
    // Hide the messages are before opening a new dialog.
    $('.modal-gallery-comment-messages').hide('fast');
   
    // Build modal frame options.
    var modalOptions = {
      url: $(this).attr('link')+ '/modalframe',
      //onSubmit: onSubmitCallback,
     // onLoad: onLoadAction,
      width: 800,
      height: 600
    };

    // Open the modal frame dialog.
    Drupal.modalFrame.open(modalOptions);

    // Prevent default action of the link click event.
    return false;

  });
};

})(jQuery);

function modal_gallery_comment_form_submit($form, &$form_state) {
  if ($form['submit']['#value'] == t('Save')) {
    modalframe_close_dialog();
   }
}

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 2 Wochen 2 Tagen
  • Hey danke
    vor 2 Wochen 3 Tagen
  • Update: jetzt gibt's ein
    vor 2 Wochen 4 Tagen
  • Hallo, im Prinzip habe ich
    vor 3 Wochen 1 Tag
  • Da scheint die Terminologie
    vor 3 Wochen 2 Tagen
  • Kannst doch auch alles direkt
    vor 3 Wochen 6 Tagen
  • In der entsprechenden View
    vor 3 Wochen 6 Tagen
  • Dazu müsstest Du vermutlich
    vor 3 Wochen 6 Tagen
  • gelöst
    vor 6 Wochen 2 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 6 Wochen 3 Tagen

Statistik

Beiträge im Forum: 250233
Registrierte User: 20456

Neue User:

  • ByteScrapers
  • Mroppoofpaync
  • 4aficiona2

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 21 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association