begin process at 2012 05 29 06:34:26
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Javascript / DHTML / Ajax

 > 

JavaScript Orienté objet (POO)

 > 

Function & Méthodes

 > 

Fonction ET dans fonction if


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Fonction ET dans fonction if

mercredi 18 juillet 2007 à 15:10:37 | Fonction ET dans fonction if

chrisslk

Bonjour, tout le monde, je suis nouveau sur ce site, et presque nouveau en javascript, désolé si je m'exprime mal.

Cette fonction, je suis presque sur qu'elle est basique, et ca m'enerve un peu.
Je me suis inspiré d'un code que j'ai trouvé sur ce site dans la partie forum et je souhaite le modifié un peu...

Voici mon code :

function calcul()
{
var sp1 = document.form1.montant.value; // montant
var sp2 = sp1.replace(",",".")// montant ss vir
var sp100 = document.form1.reprise.value; //reprise
var sp101 = sp100.replace(",",".")// reprise ss vir
var sp102 = (sp2-sp101); //montant financé - reprise
if (sp102>0) {var sp103=sp102;}
else {sp103=" Erreur ! Le montant de la reprise doit être inférieur au montant financé";}
var sp3 = document.form1.duree.value; // duree
var sp4 = document.form1.teg.value; //teg %
var sp5 = sp4.replace(",",".")// teg ss vir
var sp6 = document.form1.vrpourcent.value; //vr%
var sp7 = sp6.replace(",",".")//vr% ss vir
if (sp7<35.01) {var sp8=sp7;}
else {sp8="Impossible";}
var sp9 = document.form1.vreuro.value; //vr€
var sp10 = ((sp2*sp8)/100); //VR €HT
var sp11 = document.form1.aexp.value; // cellule petit a de ^
var sp12 = (1+(sp5/100/12)); //petit a de ^
var sp13 = document.form1.math.value; // cellulle de lexposant
var sp14 = Math.pow(sp12,sp3); // exposant
if (sp103>0) {var sp15=-(((Number(sp5))/100/12)*(-(Number(sp10))+(Number(sp103))*((Number(sp14)))))/(((Number(sp12))*1)*(1-((Number(sp14)))));}
else {var sp15="Le loyer doit être supérieur à 0";}
// calcul du loyer


document.form1.montant.value=Math.round(sp2*100)/100;
document.form1.soustotal.value=Math.round(sp102*100)/100;
document.form1.mr.value=(sp103);
document.form1.vreuro.value=(sp10);
document.form1.aexp.value=Math.round(sp12*100)/100;
document.form1.math.value=Math.round(sp14*100)/100;
document.form1.resultat.value=(sp15);

}

Vous aurez compris que la partie qui m'interesse est la partie en gras et souligné. Le code dans cet état fonctionne parfaitement.
Cependant, j'aimerais rajouté une fonction ET. Actuellement, le message "Erreur...." s'affiche dans une autre cellule, afin d'éviter tout conflis de nom dans les cellules. Par contre, comme cette cellule n'est pas invisible puisque lorsque je tape un nombre dans la cellule montant (sp1; sp2), le même nombre s'affiche en tant que sp103, chose en soit toute logique, puisque mon sp102 et à ce moment positif.
 
Comment faire pour éviter que ce nombre soit visible ?

Merci pour votre aide.



(pour vous aidez, voici mon formulaire :

<td width="158" >Montant financ&eacute;  :</td>
                        <td width="162"><input name="montant" type="text" class="champcalcul" onchange="calcul(this.form1)"/></td>
                        <td colspan="2" rowspan="2" align="left"><input name="mr" rows="2" readonly="readonly" class="transparent" onchange="calcul(this.form1)"></textarea></td>
                      </tr>
                    <tr>
                      <td >Montant Reprise : </td>
                      <td><input name="reprise" type="text" class="champcalcul" onchange="calcul(this.form1)"/>
                        <input name="soustotal" type="hidden" class="champcalcul" onchange="calcul(this.form1)"/></td>
                      </tr>
                    <tr>
                      <td >Dur&eacute;e de location : </td>
                      <td><select name="duree" class="champcalcul2" onchange="calcul(this.form1)">
                        <option value="24" onchange="calcul(this.form1)">24</option>
                        <option value="36" onchange="calcul(this.form1)">36</option>
                        <option value="48" onchange="calcul(this.form1)">48</option>
                        <option value="60" onchange="calcul(this.form1)">60</option>
                       </select>
                        mois </td>
                      <td colspan="2" align="left">&nbsp;</td>
                    </tr>
                    <tr>
                      <td >Valeur R&eacute;siduelle en % : </td>
                      <td><input name="vrpourcent" type="text" class="champcalcul" onchange="calcul(this.form1)"/>
                        %</td>
                      <td colspan="2" align="left">&nbsp;</td>
                    </tr>
                    <tr>
                      <td >Val. R&eacute;siduelle en &euro; H.T. </td>
                      <td bgcolor="#FFFFFF"><input name="vreuro" type="text" class="transparent2" onchange="calcul(this.form1)" readonly="readonly"/></td>
                      <td>&nbsp;</td>
                      <td width="41" align="left">&nbsp;</td>
                    </tr>
                    <tr>
                      <td >&nbsp;</td>
                      <td><input type="hidden" name="teg" value="4.5"  onchange="calcul(this.form1)"/>
                        <input type="hidden" name="aexp" onchange="calcul(this.form1)"/>
                        <input type="hidden" name="math" onchange="calcul(this.form1)"/></td>
                      <td colspan="2" align="left">&nbsp;</td>
                    </tr>
                    <tr>
                      <td bgcolor="#FFFFFF" ><span class="gras">Loyer en &euro; H.T.</span></td>
                      <td colspan="3" bgcolor="#FFFFFF"><input name="resultat" type="text" class="transparent"  onchange="calcul(this.form1)" readonly="readonly"/> <input type="hidden" name="objet" value="Nouvelle demande" /></td>

)

Au début de chaque instution, l'homme se demande ce qu'il peut faire pour elle, puis au bout d'un certain temps, ce qu'elle peut faire pour lui --> <a href="http://www.skeumsleague.com/b

jeudi 19 juillet 2007 à 14:47:43 | Re : Fonction ET dans fonction if

Kysic

Membre Club
Bonjour, je suis pas tout d'avoir tout compris (j'ai pas tout lu), mais je me lance quand même:
if (sp102>0 && sp101>0) {sp103=sp102;}
else {sp103=" Erreur ! Le montant de la reprise doit être inférieur au montant financé";}
ou alors :
if (!(sp102>0) && sp101>0) sp103=" Erreur ! Le montant de la reprise doit être inférieur au montant financé";
else if (sp102 > 0
&& sp101>0) sp103=sp102;
(un et dans un if c'est &&, un ou c'est ||)
[ Lien ]
jeudi 19 juillet 2007 à 16:23:32 | Re : Fonction ET dans fonction if

chrisslk

ok merci, ca m'a compris de comprendre la fonction && et ||.
Cependant, ce n'était pas la réponse "exact" de ce que j'attendais.

En fait, je souhaite ne faire afficher sp103 que si et seulement si sp102 > 0 et la je bloque.

Donc, j'ai fais ceci (j-utilise les mots ça sera plus pratique) :

- mettre le montant a financé
-mettre le montant de la reprise
// dans une cellule caché apparait le montant de l'opération suivante : montant financé moins montant de la reprise

Mon probleme est que lorsque le ce calcul est inférieur a 0, (la reprise est supérieur au montant à financé), je souhaite faire afficher un message : " Le montant de la reprise doit être inférieur au montant financé". Donc vous me direz que ca marche...
Mais le véritable probleme est que le résultat de cette soustraction s'affiche tout le temps, or je ne veux pas la voir.

J'espère que j'ai été claire...


Au début de chaque instution, l'homme se demande ce qu'il peut faire pour elle, puis au bout d'un certain temps, ce qu'elle peut faire pour lui -->http://www.skeumsleague.com/blog
jeudi 19 juillet 2007 à 16:24:38 | Re : Fonction ET dans fonction if

chrisslk

EDIT :::

je souhaite voir afficher sp103 que si et seulement si sp102 < 0

Au début de chaque instution, l'homme se demande ce qu'il peut faire pour elle, puis au bout d'un certain temps, ce qu'elle peut faire pour lui --> <a href="http://www.skeumsleague.com/b
jeudi 19 juillet 2007 à 17:49:59 | Re : Fonction ET dans fonction if

Kysic

Membre Club
Réponse acceptée !
Peut être comme cela alors:
function calcul()
{
var sp1 = document.form1.montant.value; // montant
var sp2 = sp1.replace(",",".")// montant ss vir
var sp100 = document.form1.reprise.value; //reprise
var sp101 = sp100.replace(",",".")// reprise ss vir
if (sp101 == "" || sp2 == "") return;
var sp102 = (sp2-sp101); //montant financé - reprise
if (sp102>0) {var sp103=sp102;}
else {sp103=" Erreur ! Le montant de la reprise doit être inférieur au montant financé";}
var sp3 = document.form1.duree.value; // duree
var sp4 = document.form1.teg.value; //teg %
var sp5 = sp4.replace(",",".")// teg ss vir
var sp6 = document.form1.vrpourcent.value; //vr%
var sp7 = sp6.replace(",",".")//vr% ss vir
if (sp7<35.01) {var sp8=sp7;}
else {sp8="Impossible";}
var sp9 = document.form1.vreuro.value; //vr€
var sp10 = ((sp2*sp8)/100); //VR €HT
var sp11 = document.form1.aexp.value; // cellule petit a de ^
var sp12 = (1+(sp5/100/12)); //petit a de ^
var sp13 = document.form1.math.value; // cellulle de lexposant
var sp14 = Math.pow(sp12,sp3); // exposant
if (sp103>0) {var sp15=-(((Number(sp5))/100/12)*(-(Number(sp10))+(Number(sp103))*((Number(sp14)))))/(((Number(sp12))*1)*(1-((Number(sp14)))));}
else {var sp15="Le loyer doit être supérieur à 0";}
// calcul du loyer


document.form1.montant.value=Math.round(sp2*100)/100;
document.form1.soustotal.value=Math.round(sp102*100)/100;
document.form1.mr.value=(sp103);
document.form1.vreuro.value=(sp10);
document.form1.aexp.value=Math.round(sp12*100)/100;
document.form1.math.value=Math.round(sp14*100)/100;
document.form1.resultat.value=(sp15);

jeudi 26 juillet 2007 à 15:27:03 | Re : Fonction ET dans fonction if

chrisslk

Oki, non seulement ca marche, mais en plus j'ai compris

Au début de chaque instution, l'homme se demande ce qu'il peut faire pour elle, puis au bout d'un certain temps, ce qu'elle peut faire pour lui --> <a href="http://www.skeumsleague.com/b


Cette discussion est classée dans : var, document, value, form1, montant


Répondre à ce message

Sujets en rapport avec ce message

Probleme de debutant [ par darkwhite ] Salut a tous. J'ai commencer le Javascript depuis une semaine donc je debute tout juste.J'ai commencé ce programme simple : .:Darlwhite:. Si superieur... [ par christuckers ] Salut les CSistes !!!Aujourd'hui, pour pas changer, question, bete, qui je pense, vous demandera pas trop d'effort...Voici mes calculs javascripts :fu Control et insertion dans des cellules [ par christuckers ] Salute tout le monde !Bon ba la j'ai l'impression de bloqué sur un truc completement ridicule. Je me dis que j'ai réussi à faire un truc de iouf, mais Creer un formulaire de calcul [ par quinton75 ] Bonjour, J'essaie de crée un formulaire qui multiplie le nombre de place par le prix mais ça ne fonctionne pas [^^sad2][^^sad2] [code=js] func Comparaison qui ne fonctionne pas [ par KaiHo ] Bonjour, Je fais appel à vous parce que je ne suis pas un expert en javascript (qui a dit que je débutais[^^yeuxenlair] ?) et je sèche sur un problèm Vérification formulaire [ par maha1987 ] salut tout le monde, j'ai un formulaire html et css mais le controle javascript ne fonctionne pas j'ai essayé même avec le jquery mais toujours le mê insertion des donne javascripte dans une bdd [ par somapi ] salue les amies j'ai un pFe qui consiste à crée une ma interactive bon, ma problème c'est que j'ai des donne dans ma base j aimerait bien récupère ces envois de formulaire ajax [ par Annadrill ] bonjour,voilà, j'aimerais modifier la fonction que je vous mets la dessous, de manière a pouvoir l'utiliser avec n'importe quel formulaire, en précisa XMLHTTPRequest & FF [ par spinosaurus ] Bonjour à toutes et tousje galère depuis plusieurs jours pour rendre compatible multi-navigateur un de mes scripts utilisant du XHR. Je suis allé foui récuperer données table [ par anasjava ] Je suis débutant en java  et  j'ai  un petit souci, je remli une table par des donnée


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,764 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales