Avatar billede phhepl Nybegynder
31. august 2005 - 09:40 Der er 9 kommentarer og
2 løsninger

Alert ved bestemt valg af option i select boks

Hej,

Kort: Det jeg skal have lavet er en alert som popper frem hvis besteme <option> bliver valgt i en <select>-noks.

jeg har en <select> med nogle <option>'s som kunne se sådan her ud
<select name="lady">
<option value="90">Metode 1</option>
<option value="95">Metode 2</option>
<option value="110">Metode 3</option>
<option value="290">Metode 4</option>
</select>

Jeg kan udskrive et array med de ids (values) som der skal komme en advarsel på f.eks.

advarsel = array(90,110);

hvis så 'metode 1' eller 'metode 3' bliver valgt skal der kommer en alert boks frem, ellers ikke.

Nogen forslag?
Avatar billede softspot Forsker
31. august 2005 - 09:47 #1
<select name="lady" onchange="checkAlert(this)">
<option value="90">Metode 1</option>
<option value="95">Metode 2</option>
<option value="110">Metode 3</option>
<option value="290">Metode 4</option>
</select>

<script type="text/javascript">
function checkAlert(obj)
{
  if(obj.options[obj.selectedIndex].value == "90" || obj.options[obj.selectedIndex].value == "110")
    alert('besked!');
}
</script>
Avatar billede phhepl Nybegynder
31. august 2005 - 09:51 #2
softspot kan man ikke ligge alle værdierne i et array og så lave noget ala (PHP)

$advarsel_id=array(90,110);
in_array(obj.options[obj.selectedIndex].value,$advarsel_id) ? print "alert" : print "ikke alert;

ellers er jeg bange for at det kan blive en meget lang i sætning.
Avatar billede nielle Nybegynder
31. august 2005 - 09:52 #3
<script type="text/javascript">
function doAlert(val)
{
    advarsel = Array(90,110);
    for (i=0; i<advarsel.length; i++)
    {
        if (advarsel[i] == val) alert("Er du helt sikker?");
    }
}
</script>

<select name="lady" onChange="doAlert(this.value)">
<option value="90">Metode 1</option>
<option value="95">Metode 2</option>
<option value="110">Metode 3</option>
<option value="290">Metode 4</option>
</select>
Avatar billede softspot Forsker
31. august 2005 - 09:58 #4
f.eks. som nielle skriver. Du kan også lave de checks der trigger advarsel til en parameter til funktionen og så søge i strengen med indexOf:

function checkAlert(obj,triggers)
{
  triggers = "," + triggers + ",";
  if(triggers.indexOf(","+obj.options[obj.selectedIndex].value+",") > -1)
    alert('besked!');
}
Avatar billede softspot Forsker
31. august 2005 - 09:59 #5
Så kan din select se således ud:

<select name="lady" onchange="checkAlert(this,'90,110')">
  <option value="90">Metode 1</option>
  <option value="95">Metode 2</option>
  <option value="110">Metode 3</option>
  <option value="290">Metode 4</option>
</select>

Du kan naturligvis også bare lægge listen inde i funktionen - der er op til dig hvor tæt du vil binde data til dine funktioner... :)
Avatar billede nielle Nybegynder
31. august 2005 - 10:42 #6
En fuldstændig adskillelse af data og funktion kunne også se sådan her ud:

<script type="text/javascript">
function doAlert(val, triggers, errMsg)
{
    advarsel = triggers.split(",");
    for (i=0; i<advarsel.length; i++)
    {
        if (advarsel[i] == val)
        {
            alert(errMsg);
            break;
        }
    }
}
</script>

<select name="lady" onChange="doAlert(this.value, '90,110', 'Er du helt sikker?')">
<option value="90">Metode 1</option>
<option value="95">Metode 2</option>
<option value="110">Metode 3</option>
<option value="290">Metode 4</option>
</select>
Avatar billede phhepl Nybegynder
31. august 2005 - 11:07 #7
fornemt , begge er sådan set rigtig - smider i et svar?
Avatar billede softspot Forsker
31. august 2005 - 11:09 #8
Velbekomme :)
Avatar billede nielle Nybegynder
31. august 2005 - 11:22 #9
Svar :^)
Avatar billede phhepl Nybegynder
31. august 2005 - 11:48 #10
Takker!
Avatar billede softspot Forsker
31. august 2005 - 12:27 #11
Selv tak :)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester