IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

jQuery Discussion :

Remplir un kendoDropDownList avec appel Ajax


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2015
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2015
    Messages : 75
    Par défaut Remplir un kendoDropDownList avec appel Ajax
    Salutation à tous!!!

    Voila je travail en ce moment avec l'API de KendoUI. Et la j'expérimente l'utilisation d'un kendoDropDownList (une liste déroulante avec une recherche avec autocompletion lien ici: http://demos.telerik.com/kendo-ui/dr...erverfiltering). Du coup j'essaie charger cette liste avec une action d'un de mes controller sur Symfony. Pour cela kendoUI utilise des datasource et j'essaie de faire un appel ajax dessus pour récupérer mes données. Mais Pour l'instant rien ne fonction et je trouve rien sur internet sur charger ce kendoDropDownList en utilisant du php.

    voici le javascript:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    $("#recherche_pef").kendoDropDownList({
            filter: "startswith",
            dataTextField: "NomPEF",//valeur à rechercher
            dataValueField: "IDPEF",//valeur retounrné après recherche (genre id pour traitement)
            placeholder: "Rechercher un PEF/DP...",
            dataSource: {
                //type: "odata",
                serverFiltering: true,
                transport: {
                    /*read: {
                        //url: "EventsSaisieDepart/RecherchePEF",
                        url: "RecherchePEF",
                        dataType: "json"
                    }*/
                    read: function(options) {
                        $.ajax({
                            type: "GET",
                            url: "EventsSaisieDepart/RecherchePEF",
                           // contentType: "application/json; charset=utf-8",
                            dataType: 'json',
                            //data: JSON.stringify({key: "value"}),
                            success: function(data) {
                                options.success(data);
                            }
                        });
                    }
                }
            }
        });
    L'action de mon controller symfony:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    public function RecherchePEFAction(){
                $test = "coucou";
                $test2 = $_GET['$inlinecount'];
                $test3 = $_GET['filter'];
                //$tab = array();
                $tab = array("IDPEF"=>"1", "NomPEF" => "gare du nord");
                //$tab = array("IDPEF"=>"2", "NomPEF" => "gare du sud");
                //$tab = array("IDPEF"=>"3", "NomPEF" => "gare de l'est");
                return json_encode($tab);
                //var_dump($tab);
                }
    Voila quelqu'un aurait-il une solution ou s'y connaitrait en kendoUI ?? Car la je bloque complètement... Merci d'avance!!!

  2. #2
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2015
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2015
    Messages : 75
    Par défaut
    J'ai trouvé la solution depuis un moment et j'ai oublié de poster la solution . Donc je suis passé par la création d'une datasource pour alimenter mon kendoDropDownList.

    Voici le code javascript:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    var pef={{liste_pef|raw}};
        Listepef = new kendo.data.DataSource({
                            data:pef,
                            sort: {
                                field: 'nom',
                                dir: 'asc'
                            }
                       });
       $("#recherche_pef").kendoDropDownList({
            filter: "startswith",
            dataTextField: "nom",//valeur à rechercher
            dataValueField: "code",//valeur retounrné après recherche (genre id pour traitement)
            optionLabel: "Rechercher",
            dataSource:Listepef,
            change: function(e) {
                var id_pef = $("#recherche_pef").data("kendoDropDownList").value();
     
                $.ajax({
                    type: 'POST',
                    url : "{{ path('miseaJourPEF')}}", 
                    dataType : 'text', // on spécifie bien que le type de données est en JSON
                    data : {
                        id_pef: id_pef // on donne la chaîne de caractère tapée dans le champ de recherche
                                },
                    success : function(data){ // on se prépare à renvoyer les données réceptionnées grâce à l'évènement de succès
     
                            var new_data = $.parseJSON(data);
                           // console.log(new_data);
                         $("#treeview_copie").data("kendoTreeView").dataSource.data(new_data);
     
     
                    },
                    error : function(erreur){
                        alert("Une erreur est survenue "+ erreur);
                        console.log(erreur);
                    }
                });
              },
              open: function () { $("#recherche_pef").getKendoDropDownList().list.find("k-list-optionlabel").first().hide(); 
                    }
     
        });
    Le code php qui me permet de charger ma liste:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $req_pef = $em->getRepository('gideBundle:PEF')->listePEFrecherche();
                    $liste_pef=json_encode($req_pef);
     
                 return $this->get('templating')->renderResponse('AppliBundle:Dep:Copie.html.twig', array( 
                        'liste_pef'=>$liste_pef
     
                ));

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Perte d'information avec appel AJAX
    Par zadoner33 dans le forum AJAX
    Réponses: 3
    Dernier message: 21/06/2016, 14h39
  2. 2 appels $.ajax avec jQuery
    Par Sam457 dans le forum jQuery
    Réponses: 4
    Dernier message: 26/11/2009, 23h25
  3. remplir un select avec ajax
    Par gtraxx dans le forum jQuery
    Réponses: 4
    Dernier message: 12/06/2009, 09h31
  4. [AJAX] Ajax avec appel popup d'un fichier jpg
    Par caraibes dans le forum AJAX
    Réponses: 1
    Dernier message: 29/04/2009, 01h55
  5. [DOM] Utilisation d'une bibliothèque de tri avec appel AJAX
    Par GreatDeveloperOnizuka dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 08/02/2008, 11h09

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo