molily: public protected and private in javascript

Beitrag lesen

Die Kapselung erfolgt nicht so, dass sie für einen OO Ansatz wirklich verwendbar ist.

Die Fähigkeiten von JavaScript sind in dem Punkt nicht miteinander verknüpft.

Konstruktoren und deren prototype-Eigenschaften sind ein gesondertes Ding, das sich nicht in die Sprache einfügt. Dass sie keine Private Members einführen, halte ich eigentlich noch für stimmig. Das wäre ja plötzlich »Magie«, während alles andere sich mit der Property Lookups, Prototype Chain, der Scope Chain usw. erklären lässt.

Funktionen hängen ja nur lose an Objekten und sie nicht an sie gebunden. Daher wäre es erst einmal unlogisch, ihnen besondere Rechte beim Zugriff auf andere Objektmember zu geben. Ihre Beziehung zum Objekt ist keine besondere, höchstens in dem Sinne, dass ihr die Hat-Beziehung durch »this« mitgeteilt wird, wenn sie über diesen Pfad aufgerufen wird.

Dass JavaScript hier Features hat, die nicht widerspruchslos miteinander kombinierbar sind, ist bekannt. Es kommt nicht von ungefähr, dass Crockford das Konstruktor-Prototyp-Pattern als irreführend verurteilt. Das ist es tatsächlich. Es referiert auf klassenbasierte OOP, löst diese aber nicht ein, weil JS nur einfache Objekte und First-Class-Funktionen kennt. Es ist weder wirklich funktional (was Kapselung durch Funktionsscops und Closures erlauben würde) noch wirklich prototypisch (was einfache Delegation erlauben würde).

Darum ging es in der vorgestellten Bibliothek von Florian und darum ging es mir in der Diskussion.

Die Idee, beides zusammenzubringen, halte ich ja nicht für falsch. Wie gesagt, das ist absolut nichts neues. Die einen gehen den Weg, dass sie Konstruktoren/prototype-Eigenschaften gar nicht mehr verwenden und direkt auf funktionale/prototypische OOP setzen. Mootools geht den Weg, dass sich Methoden mit dem $protected-Flag versehen lassen (function () {}.protect()). Da Mootools wie gesagt sowieso jeden Methodenaufruf kapselt, prüfen sie bei der Gelegenheit einfach auch den $protected-Flag (siehe Mootools' Class.js). Wenn ich das richtig sehe, müsste es genauso möglich sein, sämtliche Methoden mit _-Präfix automatisch protected zu machen.

Das sind alles »behutsamere« Methoden, wo ich mich frage, ob das nicht schon völlig ausreicht. Mootools Implementierung ist unter dem Strich sehr kompakt und einfach.

Ich kritisiere das Konzept gar nicht, ich bin es nicht anders gewohnt.

Es ist aber kritikwürdig und selbst die Gurus verteufeln es. ;)

Mathias

0 112

public protected and private in javascript

Florian Bücklers
  • javascript
  1. 0
    Struppi
    1. 0
      jobo
      1. 0
        jobo
      2. 0
        Florian Bücklers
        1. 1

          Standortbestimmung: Programmierparadigmen, OOP, OOP in JS ...

          peterS.
          1. 0
            Florian Bückkers
            1. 0
              peterS.
              1. 0
                jobo
              2. 0
                Florian Bücklers
              3. 2
                peterS.
                1. 0
                  peterS.
            2. 3
              molily
      3. 0
        molily
        1. 0
          jobo
  2. 1
    Struppi
    1. 0
      Florian Bücklers
  3. 2
    molily
    1. 0

      javascripts oop und ein beispiel

      jobo
      1. 0
        Struppi
    2. 1
      Florian Bücklers
      1. 1
        molily
        1. 0
          Struppi
          1. 1
            molily
            1. 0
              Struppi
              1. 0
                jobo
                1. 0
                  Struppi
              2. 1
                molily
                1. 0
                  Struppi
                  1. 0
                    molily
                    1. 0
                      Struppi
                      1. 0
                        jobo
                        1. 0
                          Struppi
                          1. 0
                            jobo
                          2. 1
                            molily
                            1. 0
                              jobo
                              1. 0
                                jobo
                  2. 1
                    molily
                2. 0
                  Florian Bücklers
                  1. 0
                    jobo
                    1. 0
                      Struppi
                      1. 0
                        jobo
                        1. 0
                          Struppi
                          1. 0
                            jobo
                            1. 0

                              was ist OOP und gibt es eine Implementation in Ecmascript

                              jobo
                            2. 0

                              OOP in Javascript - Object prototypisch erweitern

                              jobo
                            3. 0
                              Struppi
                              1. 0
                                jobo
                                1. 0

                                  protected und Javascript - übergeordnetes (Sicherheits-)Konzept

                                  jobo
                                2. 0
                                  Struppi
                                  1. 0
                                    jobo
                                    1. 0

                                      Diskussionszusammenfassung auf Wikipedia

                                      jobo
                                      1. 0
                                        Struppi
                                        1. 2
                                          molily
                                          1. 0

                                            Diskussionszusammenfassung von molily und node.js

                                            jobo
                                            1. 0
                                              Struppi
                                              1. 0

                                                der Punkt um den es geht ... Privatheitskonzept von Javascript

                                                jobo
                                                1. 0
                                                  Struppi
                                                  1. 0
                                                    jobo
                                                  2. 0

                                                    serverseitiges Javascript - node.js

                                                    jobo
                                                    1. 0
                                                      peterS.
                                                  3. 0

                                                    mitlesender

                                                    peterS.
                                                    • menschelei
                                                    1. 0
                                                      JürgenB
                                            2. 0
                                              molily
                                              1. 0

                                                Diskussionszusammenfassung von molily, node.js und loops

                                                jobo
                      2. 2
                        molily
                        1. 0
                          Struppi
                          1. 0

                            Privatheitskonzept in Javascript

                            jobo
                            1. 0
                              Struppi
                          2. 0
                            molily
                            1. 1
                              molily
                          3. 0
                            jobo
                            1. 0

                              Codereuse und DesignPatterns OOP ohne Vererbung und POO

                              jobo
                              1. 0
                                JürgenB
                                1. 0
                                  jobo
                          4. 0
                            Don P
                            1. 0

                              privat und (pseudo-)"Klassen" - Prototype und Scopevariablen

                              jobo
                              1. 0
                                Don P
                                1. 0
                                  Struppi
                                  1. 0
                                    Don P
                                    1. 0
                                      Struppi
                                      1. 0
                                        Don P
                                        1. 0
                                          Struppi
                                          1. 0

                                            Konstruktor-Closure vs. Prototyp

                                            molily
                                            1. 0
                                              jobo
                                          2. 0
                                            jobo
                                            1. 0
                                              jobo
                                            2. 0
                                              Struppi
                                              1. 0
                                                jobo
                                                1. 0

                                                  Crockfords "module pattern" - unabhängig von YUI(YAHOO)

                                                  jobo
                                                2. 0
                                                  peterS.
                                                  1. 0
                                                    jobo
                                                    1. 0
                                                      Struppi
                                                      1. 0
                                                        jobo
                                                        1. 0
                                                          Struppi
                                                          1. 0

                                                            Performance und "this" im Kontruktor

                                                            jobo
                                                            1. 0
                                                              Struppi
                                                              1. 0
                                                                jobo
                                                                1. 0
                                                                  Struppi
                                                                  1. 0
                                                                    jobo
                                                  2. 0
                                                    Don P
                                                    1. 0

                                                      private mit "revealing module patter" und "speaking code"

                                                      jobo
                                                    2. 0
                                                      Struppi
                                    2. 0
                                      jobo
                                      1. 0
                                        Struppi
                                        1. 0
                                          jobo
                            2. 0
                              Struppi
                  2. 1
                    molily
            2. 0
              jobo
              1. 2
                molily
              2. 1
                molily
                1. 0
                  jobo