Avatar billede madssch Nybegynder
09. september 2009 - 08:48 Der er 5 kommentarer og
1 løsning

Event undefined

Hej Eksperter,

Jeg har en funktion, som opretter et div-element og sætter nogle properties:

function newDiv() {
    var dialog = document.createElement('div');
    dialog.id = dialogId;
    document.body.appendChild(dialog);

    dialogHeader.onmousedown = function() {
        DragLayer(dialogId, event);
        dragLayerIsMoving = true;
    }
}

function DragLayer(dragLayerId) {

    if (!e) var e = window.event;

    if (dragLayerId != '') {
        dragLayerOffsetX = document.getElementById(dragLayerId).offsetLeft;
        dragLayerOffsetY = document.getElementById(dragLayerId).offsetTop;
        dragLayerMouseX = e.clientX;
        dragLayerMouseY = e.clientY;

        document.onmousemove = function() {
            document.getElementById(dragLayerId).style.left = (dragLayerOffsetX + e.clientX - dragLayerMouseX) + 'px';
            document.getElementById(dragLayerId).style.top = (dragLayerOffsetY + e.clientY - dragLayerMouseY) + 'px';
        }
    }

}

Mit problem er, at i alle andre browsere end IE er "e" undefined.

Hvad gør jeg galt?
Avatar billede olebole Juniormester
09. september 2009 - 09:23 #1
<ole>

    dialogHeader.onmousedown = function(e) {
        DragLayer(dialogId, e);
        dragLayerIsMoving = true;
    }

/mvh
</bole>
Avatar billede olebole Juniormester
09. september 2009 - 09:26 #2
- og her må e være undefined i alle browsere:


function DragLayer(dragLayerId, e) {

    if (!e) var e = window.event;

    if (dragLayerId != '') {
        dragLayerOffsetX = document.getElementById(dragLayerId).offsetLeft;
        dragLayerOffsetY = document.getElementById(dragLayerId).offsetTop;
        dragLayerMouseX = e.clientX;
        dragLayerMouseY = e.clientY;

        document.onmousemove = function(e) {
            e = e ? e : event;
            document.getElementById(dragLayerId).style.left = (dragLayerOffsetX + e.clientX - dragLayerMouseX) + 'px';
            document.getElementById(dragLayerId).style.top = (dragLayerOffsetY + e.clientY - dragLayerMouseY) + 'px';
        }
    }

}

Avatar billede madssch Nybegynder
09. september 2009 - 09:38 #3
Lige præcis!

Smider du et svar?
Avatar billede olebole Juniormester
09. september 2009 - 09:42 #4
- kommer her *griiiiiiiiiiiiiiiiiiiiiiiiiiib*  =)
Avatar billede madssch Nybegynder
09. september 2009 - 09:46 #5
Takker mange gange for hjælpen!
Avatar billede olebole Juniormester
09. september 2009 - 09:51 #6
Selvtak - og tak for points  =)
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