Partage
  • Partager sur Facebook
  • Partager sur Twitter

[HTML], [CSS], [PHP] Formulaire

11 janvier 2022 à 20:25:49

Bonjour, 

Je suis en train de créer un formulaire de contact. Je reçois toutes les réponses par mail, le seul problème que je rencontre est avec l'input type radio. Lorsque je m'envoie la réponse mon input radio me renvoie la réponse oui, alors que je coche la réponse non. 

Je vous met mon code ici : 

<label> Nom </label>
<input id="name" type="text" placeholder="Nom" required>

<label> Prénom </label>
<input id="prenom" type="text" placeholder="Prenom" required>

<label> Adresse Mail </label>
<input id="email" type="email" placeholder="Adresse Email" required>

 <p> Seriez-vous présent <br> à la soirée ? </p>

<input type="radio" id="radio" name="radio" value="Oui">
<label for="radio"> oui </label>

<input type="radio" id="radio1" name="radio" value="Non">
<label for="radio1"> Non </label>

<p class="textarea"> Message </p>
<textarea id="body" rows="5" placeholder="Message" required></textarea>

<button type="button" onclick="sendEmail()" value="Envoyer mon message"> Envoyer mon message </button>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>

  <script>
    function sendEmail(){
      var name = $("#name");
      var prenom = $("#prenom");
      var email = $("#email");
      var radio = $("#radio");
      var radio1 = $("#radio1");
      var body = $("#body");

      if(isNotEmpty(name) && isNotEmpty(prenom) && isNotEmpty(email)  && isNotEmpty(body) && isNotEmpty(radio) && isNotEmpty(radio1)){
        $.ajax({
          url: 'sendEmail.php',
          method: 'POST',
          dataType: 'json',
          data:{
            name: name.val(),
            prenom: prenom.val(),
            email: email.val(),
            body: body.val(),
            radio: radio.val(),
            radio1: radio1.val()
          }, success: function(response){
            $('#myForm')[0].reset();
            $('.sent-notification').text ("Votre message à bien été envoyé.");
          }
        });
      }
    }
    function isNotEmpty(caller){
      if(caller.val() == ""){
        caller.css('border','1px solid red');
        return false;
      }
      else 
      {
        caller.css('border','');
        return true;
      }
    }
  </script>



<?php 
use PHPMailer\PHPMailer\PHPMailer;

if(isset($_POST['name']) && isset($_POST['prenom']) && isset($_POST['email']) && isset($_POST['radio']) && isset($_POST['radio1'])){
    $name = $_POST['name'];
    $prenom = $_POST['prenom'];
    $email = $_POST['email'];
    $body = $_POST['body'];
    $radio = $_POST['radio'];
    $radio1 = $_POST['radio1'];

    require_once "PHPMailer/PHPMailer.php";
    require_once "PHPMailer/SMTP.php";
    require_once "PHPMailer/Exception.php";

    $mail = new PHPMailer();

    //smtp settings 
    $mail->isSMTP();
    $mail->Host = "smtp.gmail.com";
    $mail->SMTPAuth = true;
    $mail->Username = "maildenvoie";
    $mail->Password = "mdp";
    $mail->Port = 465;
    $mail->SMTPSecure = "ssl";

    // email settings 
    $mail->isHTML(true);
    $mail->setFrom ($email, $name , $prenom);
    $mail->addAddress("maildereception");
    $mail->Body = ("Nom : $name. <br/><br/> Prénom : $prenom. <br/><br/> Adresse Mail : $email. <br/><br/> seriez vous à la soirée ? : $radio. Corps du message : $body.");

    if($mail->send()){
        $status = "success";
        $response = "Votre email a bien été envoyé";
    }
    else
    {
        $status = "failed";
        $response = "Something is wrong: <br>" . $mail->ErrorInfo;
    }

    exit(json_encode(array("status" => $status, "response" => $response)));

}

?>

Je n'arrive pas a trouver de répons.

Pouvez-vous m'aider svp

Merci beaucoup

Sarah

-
Edité par SarahCohen9 11 janvier 2022 à 22:39:53

  • Partager sur Facebook
  • Partager sur Twitter
11 janvier 2022 à 20:36:46

Bonsoir.

Comme dis sur grafitark. Ton problème viens du js où il faut vérifier ce qui est cocher. 

Et change ton titre car tu vas te faire reprendre par un modo.

Il suffit de chercher js radio buttons checked sur ton moteur de recherche favori

  • Partager sur Facebook
  • Partager sur Twitter
11 janvier 2022 à 21:04:45

Hello.

Dans la mesure où tes boutons ont comme name radio, la valeur du bouton coché s'obtient facilement comme ceci :

document.querySelector('[name=radio]:checked').value

-
Edité par Domi65 11 janvier 2022 à 21:05:03

  • Partager sur Facebook
  • Partager sur Twitter
11 janvier 2022 à 21:14:22

Bonjour,

Déplacement vers un forum plus approprié

Le sujet est déplacé de la section HTML / CSS vers la section Javascript

Mauvais titre

Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

(titre originel : Formulaire)

  • Partager sur Facebook
  • Partager sur Twitter

Pas d'aide concernant le code par MP, le forum est là pour ça :)

11 janvier 2022 à 22:39:10

@aurélien Oui, mais comme l'ai dis sur l'autre groupe, j'ai vérifié ce qui était Checker, mais je ne sais pas quoi faire par la suite, toute mes tentative pour résoudre mon problème n'aboutissant a rien

  • Partager sur Facebook
  • Partager sur Twitter
5 janvier 2025 à 14:45:35

bonjour

-
Edité par NdeyeKhadyDiagne 5 janvier 2025 à 14:46:48

  • Partager sur Facebook
  • Partager sur Twitter
5 janvier 2025 à 15:15:47

Bonjour,

Le message qui suit est une réponse automatique activée par un membre de l'équipe de modération. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

Pour plus d'informations, nous vous invitons à lire les règles générales du forum

Déterrage

Citation des règles générales du forum :

Avant de poster un message, vérifiez la date du sujet dans lequel vous comptiez intervenir.

Si le dernier message sur le sujet date de plus de deux mois, mieux vaut ne pas répondre.
En effet, le déterrage d'un sujet nuit au bon fonctionnement du forum, et l'informatique pouvant grandement changer en quelques mois il n'est donc que rarement pertinent de déterrer un vieux sujet.

Au lieu de déterrer un sujet il est préférable :

  • soit de contacter directement le membre voulu par messagerie privée en cliquant sur son pseudonyme pour accéder à sa page profil, puis sur le lien "Ecrire un message"
  • soit de créer un nouveau sujet décrivant votre propre contexte
  • ne pas répondre à un déterrage et le signaler à la modération
  • Partager sur Facebook
  • Partager sur Twitter

Pas d'aide concernant le code par MP, le forum est là pour ça :)