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

AngularJS Discussion :

Une valeur issue du $scope dans le src d'un <iframe>


Sujet :

AngularJS

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Février 2008
    Messages : 764
    Par défaut Une valeur issue du $scope dans le src d'un <iframe>
    Bonjour,

    J'ai un $scope dans lequel j'ai une liste de sources pour des <iframes> que je souhaite présenter en lignes (rows...).

    J'utilise un ng-repeat et je souhaite insérer la valeur de la source dans le paramètre src du <iframe> mais cela ne fonctionne pas ! J'ai un message d'erreur file not found.
    j'ai essayé avec double moustache {{}}, simples moustaches {} et même sans moustaches ... Pourtant les autres données issues du $scope comme titre, jours et horaire fonctionnent très bien et lorsque j'affiche dans un <div> la donnée de la source, je la vois apparaître à l'écran. Mais lorsque je place le $scope dans les double quottes, ce n'est pas pris en compte.

    Une personne pourrait-elle m'aider s'il vous plaît ?

    Voici ce que j'ai fait jusqu'à présent :

    le html (c'est à la ligne 9 que je souhaite insérer la valeur de la source):
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <div id="horaires_cols" ng-repeat="horaire in horaires" class="row horaires_class_color_or">
       <div class="col-md-7">
    	   <h1 class="horaires_fontSize_2 text_align_center">{{horaire.titre}}</h1>
    	   <h1 class="horaires_fontSize_2  text_align_center">{{horaire.jours}}</h1>
    	   <h1 class="horaires_fontSize_2  text_align_center">{{horaire.horaire}}</h1>
       </div>
     
       <div class="col-md-5">
    	   <iframe src="{{horaire.source}}" frameborder="0" allowfullscreen></iframe>
       </div>
    </div>

    le module :
    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
    var app = angular.module('app', ['ui.router']);
     
    app.config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) {
     
    $stateProvider
    .state('horaires_lieux', {
    	url: '/horaires_lieux',
    	views:{
    		'general_view':{
    			templateUrl: 'horaires_lieux.htm',
    			controller: 'horaires_et_lieuxCtrl'
    		}
    	}
    })
     
    //...etc
    le controller :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    app.controller('horaires_et_lieuxCtrl', ['$scope', '$stateParams', 
    	function($scope, $stateParams) {
    		$scope.horaires = horaires;
    }]);
    le fichier data.js :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    var horaires = [
      {
        "titre": "titre 1)",
        "jours": "Tous les mercredis et samedis",
        "horaire": "de 17h00 à 20h30",
        "source": "https://www.google.com/maps/embed?pb=!1m17!1m.....etc"
      },
      {
        "titre": "titre 2",
        "jours": "Tous les vendredis",
        "horaire": "de 18h00 à 20h30",
        "source": "https://www.google.com/maps/embed?pb=!1m17!1m......etc"
     }
    ];
    mise à jour : Je me suis apperçu que le paramètre src recevait comme valeur le chemin vers un fichier {{horaire.source}} du dossier "vues" dans lequel se trouve le fichier html. J'ai modifié src par url et là je vois dans le navigateur qu'il a gardé ce paramètre et à bien mis l'url contenu dans la variable, mais cela ne fonctionne toujours pas !

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Février 2008
    Messages : 764
    Par défaut
    Salut !

    La solution que j'ai trouvé a été de rajouter un id dans les datas comme ceci :
    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
    var horaires = [
      {
        "id": "1",
        "titre": "titre 1",
        "jours": "Tous les mercredis et samedis",
        "horaire": "de 17h00 à 20h30",
        "source": "https://www.google.com/maps/embed?pb=!1m17!1m11!1m3!1d511..... etc"
      },
      {
        "id": "2",
        "titre": "titre 2",
        "jours": "Tous les vendredis",
        "horaire": "de 18h00 à 20h30",
        "source": "https://www.google.com/maps/embed?pb=!1m17!1m1.......etc"
      }
    ];
    Puis de tester la condition sur l'id et de mettre le paramètre src en dur dans le code html :
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <div class="col-md-5">
    	<iframe ng-if="horaire.id==1" src="https://www.google.com/maps/embed?pb=!1m17!1m11!1m3!1d511.79..... etc"
    			frameborder="0" allowfullscreen>
    	</iframe>
     
    	<iframe ng-if="horaire.id==2" src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m..... etc"   frameborder="0" allowfullscreen>
    	</iframe>
    </div>




    Par contre, le sujet n'est pas résolu puisque je n'ai toujours pas pu utiliser le $scope pour le paramètre src du iframe.

  3. #3
    Expert confirmé
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 419
    Par défaut
    Essaie avec la directive ngSrc au lieu de src directement.

  4. #4
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    764
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Février 2008
    Messages : 764
    Par défaut
    Bonjour,

    Merci pour votre aide.

    Voici le code html révisé contenant le ng-src :
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <div id="horaires_cols" ng-repeat="horaire in horaires" class="row horaires_class_color_or">
    	<div class="col-md-7">
    		<h1 class="horaires_fontSize_2 text_align_center">{{horaire.titre}}</h1>
    		<h1 class="horaires_fontSize_2  text_align_center">{{horaire.jours}}</h1>
    		<h1 class="horaires_fontSize_2  text_align_center">{{horaire.horaire}}</h1>
    	</div>
     
    	<div class="col-md-5">
    		<iframe ng-src="{{horaire.source}}"
    				frameborder="0" allowfullscreen>
    		</iframe>
    	</div>
    </div>

    Cela ne fonctionne pas ! j'ai essayé avec deux accolades, une seule accolade et sans accolades ....

    Ensuite, j'ai essayé comme ceci :
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <div class="col-md-5">
    	<iframe ng-src="https://www.google.com/maps/embed?pb={{horaire.source}}"
    			frameborder="0" allowfullscreen>
    	</iframe>
    </div>

    Cette fois, on peut voir une carte s'afficher mais c'est la carte générale du monde et non pas la carte d'un lieu précis dont les coordonnées sont indiquées dans la donné issue du $scope. De la même façon que précédemment, j'ai essayé avec double accolades, simples accolades, sans accolades, puis avec des simples quotes autour de la donnée du $scope. et j'ai même essayé avec $scope.horaire.source ....


Discussions similaires

  1. mettre une valeur a un champs dans un onglet..
    Par Fritzoune dans le forum Access
    Réponses: 2
    Dernier message: 03/03/2006, 14h33
  2. [MySQL] Affichage d'une valeur de la bdd dans un input
    Par leloup84 dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 23/02/2006, 12h28
  3. récuperer une valeur et l'afficher dans un input
    Par popy29 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/12/2005, 16h49
  4. insérer une valeur de type float dans une abse de données
    Par Stephane_br dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/11/2005, 10h47
  5. [MySQL] Pb d'insertion d'une valeur de champ select dans une Bdd
    Par Mimisator dans le forum PHP & Base de données
    Réponses: 20
    Dernier message: 20/10/2005, 18h51

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