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

[gelöst] Callback mit neuen Argumenten aufrufen

Eingetragen von bit-checker (28)
am 27.03.2015 - 14:55 Uhr in
  • Modul-Entwicklung

Hallo,
ich habe ein kleines Modul geschrieben, welches duch Callback und entsprechende Argumente aufgerufen wird und einen Node erstellt, funktioniert auch soweit.
Jetzt möchete ich im Node ein Button haben, der den Node mit anderen Argumenten aufruft. Wie kann ich das lösen?

<?php

function my_menu() {
   
$items = array();
// Eingangsvariablen
   
$anz_wochen = '2';
   
$start_tag = date('Y-m-d');
   
   
$items['fahrzeug_liste'] = array(
       
'title' => 'Fahrzeug- Liste',
       
'page callback' => 'liste_node',
       
'page arguments' => array($anz_wochen, $start_tag),
       
'access arguments' => array('access content'),
       
'file' => 'includes/my.fahrzeugliste.inc',
       
'type' => MENU_NORMAL_ITEM,
    );
    return
$items;

?>

‹ *GELÖST* Fehler bei SQL INSERT [gelöst] Callback mit neuen Argumenten aufrufen ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Muss es denn unbedingt ein

Eingetragen von SteffenR@drupal.org (2262)
am 28.03.2015 - 22:41 Uhr

Muss es denn unbedingt ein Button sein?
Hier könntest du auch einfach einen Link in deinen Node packen - bspw. über das Node Template oder über ein eigenes Feld (Display Suite Custom Field) . Diesem Link könntest du dann problemlos alle Parameter anhängen.
Eigenes Feld zu Content Type hinzufügen (Drupal Fields): http://timonweb.com/posts/adding-a-custom-extra-field-to-entity-node-dis...
Per Display Suite kannst du es auf diese Weise erstellen: https://www.drupal.org/node/1795314

Das Styling würde dann über CSS erfolgen.

Ein Button sollte eigentlich nur verwendet werden, wenn du hier auch ein Formular zum Abschicken auf der Seite hättest.

SteffenR

  • Anmelden oder Registrieren um Kommentare zu schreiben

ein Link kann per CSS auch als Button dargestellt werden

Eingetragen von ronald (3857)
am 29.03.2015 - 01:22 Uhr

das ist ein bisschen CSS-Bastelei, nichts weiter.

Oder man hinterlegt ein JavaScript, das aus dem Aufrufziel und diversen Paramern ein verstecktes Formular bastelt, und bei klick auf den Sendenbutton verschickt.

Will man nicht, dass eine Zielseite geladen wird, sondern nur einen kleinen Feedback einblenden, muss man diesen Aufruf über AJAX abwickeln lassen.

JQuery sei Dank ist auch das machbar, geht aber über die Standardfunktionalität von Links und Forms etwas hinaus.

  • Anmelden oder Registrieren um Kommentare zu schreiben

aber wo gebe ich die Parameter weiter?

Eingetragen von bit-checker (28)
am 29.03.2015 - 20:58 Uhr

Hmm, aber wo übergebe ich die Parameter? Doch nicht über die URL, die werden doch bei Drupal in Arrays gepackt. In meinem Fall wird ja, wenn ich die Url "http:// meineseite.de/fahrzeug_liste" aufrufe die Parameter initial aus "array($anz_wochen, $start_tag)" übergeben und meine Seite angezeigt. Diese gibt nur HTML- Code zurück. Nun möchte ich im Code ein Button einfügen, welcher die selbe Seite mit anderen Parametern läd.

Vielen Dank für Eure Hilfe!

  • Anmelden oder Registrieren um Kommentare zu schreiben

bit-checker schriebHmm, aber

Eingetragen von SteffenR@drupal.org (2262)
am 29.03.2015 - 22:08 Uhr
bit-checker schrieb

Hmm, aber wo übergebe ich die Parameter? Doch nicht über die URL, die werden doch bei Drupal in Arrays gepackt. In meinem Fall wird ja, wenn ich die Url "http:// meineseite.de/fahrzeug_liste" aufrufe die Parameter initial aus "array($anz_wochen, $start_tag)" übergeben und meine Seite angezeigt. Diese gibt nur HTML- Code zurück. Nun möchte ich im Code ein Button einfügen, welcher die selbe Seite mit anderen Parametern läd.

Vielen Dank für Eure Hilfe!

Die Page Arguments musst du schon mit in deinem hook_menu definieren. So wie du es gerade im Code machst, wird das nix.
Korrekt müsste dein Menu Item wie folgt definiert sein:

<?php


function mymodule_menu() {
$items['fahrzeug_liste/%/%'] = array(
       
'title' => 'Fahrzeug- Liste',
       
'page callback' => 'liste_node',
       
'page arguments' => array(1, 2),
       
'access arguments' => array('access content'),
       
'file' => 'includes/my.fahrzeugliste.inc',
       
'type' => MENU_NORMAL_ITEM,
   );
  return
$items;
}

function
liste_node($anz_wochen, $start_tag) {

}
?>

Auf diese Weise hättest du dann in deiner page callback Funktion auch Zugriff auf die Argumente.
Für alles Weitere lohnt auch ein Blick in der [do:examples] Modul - hier finden sich noch weitere Beispiele zum Umgang mit dem hook_menu und anderen Durpal APIs. Wie ich bereits in meiner letzten Antwort schrieb, ist es nicht notwendig hier einen richtigen Button zu verwenden - hier reicht dann ein normaler Link auf der Seite, der die entsprechenden Paramter enhält.

<a href="fahrzeug_liste/54/1">Aufruf des Callbacks mit Argumenten</a>

SteffenR

  • Anmelden oder Registrieren um Kommentare zu schreiben

[gelöst] Danke, das war's

Eingetragen von bit-checker (28)
am 30.03.2015 - 16:57 Uhr

Habe das hook_menu mit Argumenten jetzt angelegt. Funktioniert prima.

  • Anmelden oder Registrieren um Kommentare zu schreiben

bit-checker schrieb Habe das

Eingetragen von SteffenR@drupal.org (2262)
am 30.03.2015 - 19:10 Uhr
bit-checker schrieb

Habe das hook_menu mit Argumenten jetzt angelegt. Funktioniert prima.

Das freut mich zu lesen - dann weiterhin viel Spaß / Erfolg beim Umsetzen deines Projekts.

SteffenR

  • 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 24 Minuten
  • Hey danke
    vor 2 Wochen 19 Stunden
  • Update: jetzt gibt's ein
    vor 2 Wochen 1 Tag
  • Hallo, im Prinzip habe ich
    vor 2 Wochen 5 Tagen
  • Da scheint die Terminologie
    vor 2 Wochen 6 Tagen
  • Kannst doch auch alles direkt
    vor 3 Wochen 3 Tagen
  • In der entsprechenden View
    vor 3 Wochen 3 Tagen
  • Dazu müsstest Du vermutlich
    vor 3 Wochen 3 Tagen
  • gelöst
    vor 5 Wochen 6 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 6 Wochen 19 Stunden

Statistik

Beiträge im Forum: 250233
Registrierte User: 20452

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 33 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