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

JavaSkript in eigenem Modul einbinden

Eingetragen von psfjkmmmms (4)
am 15.11.2016 - 17:40 Uhr in
  • Modul-Entwicklung
  • Drupal 7.x

Hallo Leute,

ich habe hier eine sehr spezifische Frage:

Mein Team und ich sind dabei eine Website zu erstellen, näher gesagt ein Forum. Hierzu braucht man natürlich ein Registrierungsformular,
nun muss von unserem Modul die Email-Adresse ausgelesen werden können und damit unter dem Feld eine Zugehörigkeit angezeigt werden können.
Dazu haben wir ein Java Skript geschrieben was dies bewerkstelligen soll.
Das müssen wir nun in eine Hook einfügen, wo beim Verlassen des Feldes dieses Skript ausgelöst werden soll.
Hier einmal unser JavaSkript:

(function ($) {

Drupal.behaviours.user_register_form = {

attach: function (context, settings){
/**
* Liest den letzten Teil der Email_Adresse aus und benutzt diesen um Die Zugehörigkeit
* anzeigen zu können.
*/

var elem = document.getElementById('$mail');
//Array mit den zugehörigen Universitäten hier anonymisiert
var universities = ["", "", "", "", "", "", "", ""];
elem.addEventListener('change', checkMail);

function checkMail(){
var eingabe=elem.value;
var result = '';
for (var i = 0; i < universities.length; i++) {
var reg = new RegExp(universities[i]);
var text = eingabe.match(reg);
if (text != null) {
  result = text;
  }
}
var stringResult = "" + result + "";
useIndexes(stringResult);
}

function useIndexes(result){

var eingabe=elem.value;
var result = '';
for (var i = 0; i < universities.length; i++) {
var reg = new RegExp(universities[i]);
var text = eingabe.match(reg);
if (text != null) {
  result = text;
  }
}
var stringResult = "" + result + "";



var text = "<p id='member'></p>";
        $('mail').append(text);
switch(result){
case "___":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "__":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are are a member of the ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
case "___":
    var ausgabe = "You are are a member of ___";
    $("#member").text('');
    $("#member").append(ausgabe);
    break;
  default:
     var ausgabe = "Your are not a member of the universities please login with a personal e-mail address";
    $("#member").text('');
    $("#member").append(ausgabe);
break;
}
}
};})(jQuery);

Vielen Dank Im Voraus für eure Hilfe.

Bis dann,

psfjkmmmms

‹ Drupal 8 hook_ für save, edit und delete JavaSkript in eigenem Modul einbinden ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Hallo, Du könntest das

Eingetragen von Hyp1 (1463)
am 15.11.2016 - 17:53 Uhr

Hallo,

Du könntest das Verhalten(behavior) der Felder an einen onChange Handler binden:

Drupal.behaviors.exampleModule = {
  attach: function (context, settings) {
    $('#member', context).onchange(function () {
      alert("Feld geändert");
    });
  }
};

Gruss

Robert

  • Anmelden oder Registrieren um Kommentare zu schreiben

Nicht ganz klar!

Eingetragen von psfjkmmmms (4)
am 16.11.2016 - 13:42 Uhr

Erstmal vielen Dank für die schnelle Reaktion.
Mir ist leider nicht klar wo genau ich den code jetzt einbinden muss, damit er das JavaScript ausführt.
Könntet ihr versuchen so genau wie möglich zu seien.
Zur Ergänzung noch mein selber erstelltes Modul:

<?php

/**
* @file
* A module which implements the parsing of the mail adress with a javascript and shows the taxonomy and user role.
*/

/**
* Implements hook_help.
*
* Displays help and module information.
*
* @param path
*   Which path of the site we're using to display help
* @param arg
*   Array that holds the current path as returned from arg() function
*/
function registering_module_help($path, $arg) {
  switch ($path) {
    case "admin/help#registering_module":
      return '<p>'.  t("Defines the options which are supported.") .'</p>';
      break;
  }
}
//Hier die Versuche das Java Script einzubinden.
//drupal_add_js('jQuery(document).ready(function () { alert("Hello!"); });', 'inline');

/* function registering_module_form_alter(&$form, &$form_state, $form_id) {
if ($form_id == 'user_register_form') {
$form['#attached']['js'][] = array (
'type' => 'external',
'data' => drupal_get_path('module','mailparser') . '/mailparser.js',
);
$form['account']['mail']['#description'] = t('Dies ist ein Test');
}
} */
Drupal.behaviors.registering_module = {
attach: function (context, settings) {
$('#member', context).onchange(function () {
alert("Feld geändert");
});

function registering_module_form_alter(&$form, &$form_state,$form_id){
if ($form_id == 'user_register_form'){
$form['mail']['#ajax'] = array(
'callback' =>'formmsgs_image_style_mail',
'event' => 'change',
'wrapper' => 'formmsgs-image-style-mail',
);
$form['mail']['#ajax'] = array();
$form['terms_of_use'] = array(
'#type' => 'checkbox',
'#title' => t("I agree with the website's terms and conditions and the behaviour."),
'#required' => TRUE,
'#weight' => 13,
);
}
};
$form['account']['mail']['#description'] = '<div id="formmsgs-image-style-mail"> If you are a member of an university, please use your university email-address.   </div>';
$form['account']['mail']['#default_value'] =  "___";
}
}

Vielen Dank.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hi,da gibt es mehrer

Eingetragen von Hyp1 (1463)
am 18.11.2016 - 02:16 Uhr

Hi,

da gibt es mehrer Möglichkeiten.

in der Modul *.info oder *.yml kannst Du dein Skript laden.

oder über die Modul API:

//Module init Hook
function registering_module_init(){
drupal_add_js('jQuery(document).ready(function () { alert("Hello!"); });', 'inline');
}

oder du kannst über die Form API #attached benutzen:
http://drupal.stackexchange.com/questions/70015/adding-css-and-js-to-form-with-attachments

Gruss

Robert

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • Rolle erstellen nicht zu finden
  • 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
Weiter

Neue Kommentare

  • Arrrrg. Nix Tabelle :-D /*
    vor 3 Wochen 4 Tagen
  • Textboxen mit Tabelle
    vor 3 Wochen 4 Tagen
  • Du sollst ja auch keine
    vor 3 Wochen 4 Tagen
  • Theme
    vor 3 Wochen 4 Tagen
  • Welches Theme benutzt du
    vor 3 Wochen 4 Tagen
  • Mit Responsive Raster hatte
    vor 3 Wochen 5 Tagen
  • Hallo Alex,um das Häkchen
    vor 3 Wochen 5 Tagen
  • Modul view_unpublished
    vor 3 Wochen 6 Tagen
  • Modul "override node options"
    vor 4 Wochen 17 Stunden
  • Im Grunde ist dass ein
    vor 4 Wochen 2 Tagen

Statistik

Beiträge im Forum: 250270
Registrierte User: 20483

Neue User:

  • Aathivithyah
  • Aoirhic
  • Stevebok

» Alle User anzeigen

User nach Punkten sortiert:
wla9463
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 35 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