Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JS][OOP]Obiekt czy funkcja.
daniel1302
post
Post #1





Grupa: Zarejestrowani
Postów: 602
Pomógł: 30
Dołączył: 1.08.2007
Skąd: Nowy Sącz

Ostrzeżenie: (0%)
-----


Witam, projektuję aplikację obiektową niby w JS ale też OOP. Teraz mam dylemat:
Mam klasę sterującą aplikacją- Application();
oraz klasę zajmującą się sterowaniem w tej aplikacji(obsługa myszy, klawiatury itp)- AppControl();. Klasa AppControl przechowuje informacje o zachowaniach na daną reakcję(naciśnięcie klawisza):
  1. app.appControl.addKeyEvent('escape', nacisnijEscape(), puscEscape());

Dane przechowywane są w tablicy

I teraz mam to rozwiązane tak:
Klasa Application posiada instancje obiektu AppControl();, i wygląda tak:
  1. function Application()
  2. {
  3. var appControl = new AppControl();
  4. .
  5. .
  6. .
  7. }

i teraz operacje wyglądają nastepująco:
  1. var app = new Application ();
  2. app.appControl.addKeyEvent('left', przesunWLewo());



Tylko zastanawiam sie czy funkcje obiektu appControl nie powinny być funkcjami obiektu Application?
Bo w sumie nie wiem czy jest sens tworzyć nowy obiekt tylko w jednym miejscu(bo raczej sterowanie nie będzie dublowane).
Jest jeden mały problem. Bo nie pausje mi ładowac wszystkiego do jednego pliku(bo klasa Application nie zajmuje wiele(6kB), ale klasa sterowania narazie zajmuje 12 kB a będzie rozbudowywana.
Czy jest jakiś inny sposób na umieszczenie funkcji dla klasy w nowym pliku poprzez rozbudowywanie prototypowe?
np:
  1. Application.prototype.addKeyEvent = function (){...}


Co wy myślicie na ten teamat. jak powinno być zrealizowane taki problem.

Nie jestem pewiem, bo JS jest językiem dynamicznym a ja pracowałem zawsze na PHP, C, Asm. I w PHP nie wachałbym się tylko stworzyłbym nową klasę, ale tutaj nie wiem
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 21.08.2025 - 02:48