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

ASP Discussion :

Fonction : récupérer le résultat


Sujet :

ASP

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 40
    Points : 26
    Points
    26
    Par défaut Fonction : récupérer le résultat
    Bonjour,

    j'utilise une fonction pour supprimer les guillemets simples de texte récupéré dans un formulaire. Je ne suis pas très familier avec l'utilisation des fonctions en ASP. Mon problème : je ne n'arrive pas à récupérer le résutat de la fonction.

    Voici mon code :

    recupCommentaire="'" & server.htmlEncode(Request("commentaire")) & "'"

    texteATraiter=recupCommentaire

    'Envoyer le texte à la fonction
    traiterTexte (texteATraiter)

    function traiterTexte (text)

    String = text

    String = Left(MaString, Len(String ) -1)
    String = Right(MaString, Len(String ) -1)
    String = "'" & Replace(String , "'", "''") & "'"
    return String

    end function


    C'est à ce niveau là que je bloque. Comment donc récupérer la chaîne traitée par la fonction ?

    Merci d'avance !

    Cristol

  2. #2
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    633
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 633
    Points : 721
    Points
    721
    Par défaut
    déjà je pense que string est un mot réservé donc tu risques des problèmes lors de l'execution du ta fonction.
    Ensuite pour récupérer ta valeur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mavariable=mafonction(mesparametres)

  3. #3
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    633
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 633
    Points : 721
    Points
    721
    Par défaut
    en passant a quoi te servent ton left et ton right ?

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 40
    Points : 26
    Points
    26
    Par défaut
    Merci pour le conseil avec string, j'ai changé ça :

    function traiterTexte (text)
    texteFonction = text
    texteFonction = Left(texteFonction, Len(texteFonction) -1)
    texteFonction = Right(texteFonction, Len(texteFonction) -1)
    texteFonction = "'" & Replace(texteFonction, "'", "''") & "'"

    response.write "texte fonction traité: "&texteFonction

    return texteFonction
    end function


    recupTexteFonction = traiterTexte (recupCommentaire)

    Quand j'appelle la fonction avec l'instruction que tu m'as donnée, ça marche mais j'ai été obligé de rajouter un response.write.

    C'est normal d'avoir fait ça ? Est-ce que je devrais pas me servir du return plutôt ? (pour l'instant il ne me sert à rien)

    Left et right :

    left (maChaine, numéro X de caractere)
    Ca renvoie le caractère numéro X dans la maChaine, en partant de la gauche.

    right (maChaine, numéro X de caractere)
    C'est la même chose en partant de la droite.

    Merci !

    Cristol

  5. #5
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    633
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 633
    Points : 721
    Points
    721
    Par défaut
    le return te permet de resortir un résultat de ta fonction pas de l'afficher.
    sans le return la fonction ne te renvoie rien.
    je verrais plutot ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    function traiterTexte (text)
    texteFonction = text
    texteFonction = Left(texteFonction, Len(texteFonction) -1)
    texteFonction = Right(texteFonction, Len(texteFonction) -1)
    texteFonction = "'" & Replace(texteFonction, "'", "''") & "'"
     
    return texteFonction
    end function
     
    recupTexteFonction = traiterTexte (recupCommentaire) 
     
    response.write "texte fonction traité: "&recupTexteFonction
    je posait la question du left et right dans ce cas précis ? je vois pas bien ce que tu cherches à faire car tu affectes ta variable une fois puis tu remplaces sont contenu, ça m'echappe...

  6. #6
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    633
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 633
    Points : 721
    Points
    721
    Par défaut
    je me reveille là mais je crois que tu te trompes de fonction si tu cherches à faire ce que tu ma dis. Left et right renvoient le nombre de caractères spécifés dans la chaine passée en paramètre.

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 40
    Points : 26
    Points
    26
    Par défaut
    En fait, ce que je fais avec cette fonction c'est ajouter un guillement simple après un autre guillement simple, sinon j'aurai une erreur sql.

    Le problème quand on traite la chaîne c'est qu'il ne faut pas traiter le 1er et le dernier caractère, c'est le rôle joué par left et right, sinon on retombe sur des guillemets double :

    sans left et right, en rajoutant un guillement simple :
    maChaine = '' l''insertion de données ''

    avec left et right, en supprimant le 1er et le dernier caractère :
    maChaine = l''insertion de données

    il faut ensuite rajouter les guillements simples pour que la requête soit bien interprétée en sql :
    maChaine = " ' " & maChaine & " ' "

    Cristol

  8. #8
    Membre actif
    Inscrit en
    Janvier 2005
    Messages
    451
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 451
    Points : 287
    Points
    287
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function toto(temp)
     
    temp = temp + "tata"
    toto = temp 
     
    end function
    moi je fais mes fonctions sans return !

  9. #9
    Membre averti Avatar de pmboutteau
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    601
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Santé

    Informations forums :
    Inscription : Février 2005
    Messages : 601
    Points : 420
    Points
    420
    Par défaut
    Pourquoi tu n'utilises pas Replace.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data1=replace(Request.Form("data1"),"'","''")
    ours ours !! Au début elle est froide mais après elle est bonne!

Discussions similaires

  1. Exécuter une fonction et récupérer le résultat
    Par coraziari_l dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 14/01/2008, 16h56
  2. Réponses: 2
    Dernier message: 27/08/2007, 13h11
  3. [C] Récupérer un résultat de fonction de type double
    Par EnigmuS dans le forum x86 32-bits / 64-bits
    Réponses: 10
    Dernier message: 23/04/2007, 10h17
  4. Récupérer le résultat d'une fonction dans une balise html
    Par Hayato dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 19/06/2006, 17h04
  5. Réponses: 6
    Dernier message: 08/06/2006, 10h07

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