Avatar billede Godfather75 Nybegynder
28. september 2015 - 14:37 Der er 3 kommentarer

konvertere js til Typescript

Hvordan tilføjer jeg denne bootstrap event i Typescript?

$("#accordion").on("shown.bs.collapse", function () {  }

Opbygning af min typescript:
module app {
  export class myClass { // min klasse
 
  constructor(){
      this.myFunction();// kalder en funktion
  }

  this.myFunction(){
  // do something
  }
  }
}
Avatar billede Slater Ekspert
28. september 2015 - 15:06 #1
Typescript konverterer til Javascript, dvs. du kan sagtens bruge ganske almindelig Javascript i det.
Avatar billede Godfather75 Nybegynder
29. september 2015 - 00:21 #2
fandt en løsning til mit problem, men den er ikke helt perfekt. Det er træls at jeg skal bruge ng-click. Det ville være bedre hvis jeg kunne injecte $('#collapseOne').on("shown.bs.collapse", (event) => this.accordionEvent()); i constructor().

Min View:
<div class="panel-group" id="accordion" role="tablist" aria-multiselectable="true">
    <div class="panel panel-default">
        <div class="panel-heading" role="tab" id="headingTwo"
ngclick="thisInstance.scroll()">.... osv..

Min Controller:
module app {
  export class myClass { // min klasse
 
  constructor(){
  }

  scroll(id: number): void {
      $('#collapseOne').on("shown.bs.collapse", (event) => this.accordionEvent());
  }

        accordionEvent() : void{
            $('html, body').animate({ scrollTop: $('#targetDiv').offset().top }, 800);
        }
  }
}
Avatar billede Slater Ekspert
29. september 2015 - 07:38 #3
Det kan du også sagtens, som sagt.
Bare husk at alle jQuery event handlers skal sættes efter document.ready
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