abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 11:00 | IT novinky

    Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.

    Ladislav Hagara | Komentářů: 2
    dnes 10:55 | Humor

    Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀

    Ladislav Hagara | Komentářů: 3
    dnes 01:00 | Komunita

    Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 1
    dnes 00:00 | IT novinky

    Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | Nová verze

    Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 05:55 | IT novinky

    Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.

    Ladislav Hagara | Komentářů: 0
    4.11. 11:33 | IT novinky

    Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.

    Ladislav Hagara | Komentářů: 22
    4.11. 05:44 | Komunita

    Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.

    Ladislav Hagara | Komentářů: 0
    4.11. 04:33 | Komunita

    Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co

    … více »
    SUSEMAS | Komentářů: 2
    4.11. 04:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (21%)
     (16%)
     (16%)
    Celkem 319 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    Rozcestník

    Implementace super() v JavaScriptu

    11.10.2011 00:35 | Přečteno: 1286× | Linux | Výběrový blog | poslední úprava: 11.10.2011 00:39

    Dlouho jsem tu nic nenapsal, to ale neznamená, že abíčko nesleduji. Chybí mi tu ale víc programátorských blogů, tak to zkusím sám napravit.

    V JavaScriptu postrádám Python-style volání super při použití dědičnosti. Proto jsem si napsal vlastní řešení. Až potom jsem našel, že existují podobné implementace.

    JavaScript nemá syntaktickou podporu pro vytváření tříd. Proto si nejprve implementujeme jednoduchý class-builder. Prefix $ jsem zvolil pro zdůraznění systémovosti.

    var $class = function(fn, fn2) {1
        if(fn === undefined) {
            return function () {};
        } else if(fn2 === undefined) {
            fn2 = function () {
                fn.apply(this, arguments);
            };
        }
    
        for(var i in fn.prototype) {
            fn2.prototype[i] = fn.prototype[i];
        }
    
        return fn2;
    };
    

    Helper funkce $class nám umožní vytvářet třídy 3 způsoby.

    1) První způsob volání $class se neliší od prostého var Animal = function() {};

    var Animal = $class();
    
    Animal.prototype.sayHello = function() {
        alert("I'm animal");
    };
    
    var myAnimal = new Animal();
    
    myAnimal.sayHello();
    

    2) Druhý způsob volání $class umožňuje vytvořit třídu s konstruktorem:

    var Animal = $class(function () {
        alert('Initializing animal...');                                                                                                                                                                       
    });
    

    3) Konečně poslední způsob volání $class je vytváření tříd děděním.

    var Dog = $class(Animal, function() {
        alert('Initializing dog...');
    });
    
    
    Dog.prototype.sayHello = function() {                                                                                                                                                                      
        alert("Hi, I'm dog");
    };
    
    var myDog = new Dog();
    
    Problém nastane, pokud potřebujeme volat z jakéhokoliv místa konstruktoru Dog i konstruktor Animal. To samé pro metodu sayHello. V Pythonu prostě na správném místě voláme super a je to.
    super(Dog, self).__init__()
    super(Dog, self).sayHello()
    

    V JavaScriptu si super naimplementujeme takto:

    var $super = function(fn, $this) {
        return function() {
            return fn.apply($this, arguments);
        };
    };
    

    Použitím helper funkce $super získáme přístup k metodám předka. Funkce $super samozřejmě umožňuje předávat i argumenty.

    var Dog = $class(Animal, function() {
        alert('Initializing dog...');                                                                                                                                                                          
    
        $super(Animal, this)();
    
        alert('Dog initialized');
    });
    
    Dog.prototype.sayHello = function() {
        alert("Hi, I'm dog");
    
        $super(Animal.prototype.sayHello, this)();
    
        alert("Goodbye, dog!");
    };
    

    To je vše, pokud budou následovat další blogy, budou především o Pythonu, který je můj chlebodárce :-)

           

    Hodnocení: 62 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    11.10.2011 10:00 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Proč do Javascriptu dodělávat Pythoviny jako super() a __init__ a nepoužít raději pyjamas? Z myšlenky psát webovou aplikaci v jednom jazyce, který umím (tím odpadá server side Javascript), jsem docela nadšený.
    When your hammer is C++, everything begins to look like a thumb.
    11.10.2011 11:07 diverman
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Dal jsem pyjamas 2 minuty a nezjistil jsem, jak funguje. Ve FAQ je na vsechno odpoved No/Nope. Jo zaregistroval jsem cosi o Python to JavaScript compileru-no to jsem se lekl. O server side JS v mem blogu nepadlo ani slovo, jak jsi na to prisel? Popravde-nikdy by me nenapadlo na server cpat JS.

    Odpoved na otazku proc? Protoze se muzes dostat do situace, kdy si nemuzes vybirat, v cem to budes delat, jaky knihovny muzes pouzit. Tady mas python, v prohlizeci mas JS, tak ukaz co umis.
    11.10.2011 19:28 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Pyjamas je překladač pythonu do javascriptu. Plus nějaké ty widgety a ajax. Principem je, že celou stránku prostě člověk napíše v Pythonu a přeloží do kombinace HTML+Javascript pro prohlížeč.
    O server side JS v mem blogu nepadlo ani slovo, jak jsi na to prisel? Popravde-nikdy by me nenapadlo na server cpat JS.
    Protože psát aplikaci v X jazycích je prostě opruz :-)

    Mimochodem, docela hezký Hello world je ve web2py book: JSONRPC a Pyjamas
    When your hammer is C++, everything begins to look like a thumb.
    11.10.2011 10:22 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Nepoužívejte dědičnost a nemusíte řešit super :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    Konqui avatar 11.10.2011 11:14 Konqui | skóre: 18 | blog: Konqui | Rožnov pod Radhoštěm
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    V Pythonu se mi volání super() dost hnusí, na JS je IMHO lepší použít framwork DoJo, který podporuje dedičnost a další OOP prvky
    Open/save dialogy z GTK+ jsou nejkřiklavější ukázkou toho nejdebilnějšího software, co vůbec může existovat.
    mess avatar 11.10.2011 14:03 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Osobně se mi víc líbí tento přístup.
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    11.10.2011 14:20 diverman
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Co se ti na nem libi vic, mohl bys byt konkretnejsi?
    mess avatar 11.10.2011 18:32 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Použití je takové příjemnější, například místo $super(Animal.prototype.sayHello, this)(); použiješ ve funkci sayHello toto:this._super();. "Třída" vznikne takto:
    var Animal = Class.extend({
    // members
    });
    Odvozená třída vzniká takto:
    var Dog = Animal.extend({
    // members
    });
    
    Čistě osobní pocity :-)
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    11.10.2011 17:54 pozortucnak | skóre: 21 | blog: vecny_windowsar
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Kontrolní otázka: je tu nějaké javascript IDE které je schopno u objektů vytvořených pomocí frameworků typu dojo, mootools... doplňovat metody?
    Jsem mimořádně obtížný případ
    mkoubik avatar 11.10.2011 21:06 mkoubik | skóre: 5 | blog: lorem_ipsum | Praha 8 - Bohnice
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Cloud 9 IDE.
    12.10.2011 09:31 Adam
    Rozbalit Rozbalit vše Re: Implementace super() v JavaScriptu
    Kdyz mate rad Python, tak tohle znate?

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.