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 - 16: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 - 16: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 - 12: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 - 01: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

  • 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 6 Stunden
  • Hey danke
    vor 2 Wochen 1 Tag
  • Update: jetzt gibt's ein
    vor 2 Wochen 1 Tag
  • Hallo, im Prinzip habe ich
    vor 2 Wochen 6 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 6 Wochen 3 Stunden
  • Ja natürlich. Dass ist etwas,
    vor 6 Wochen 1 Tag

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