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 10:50 | Zajímavý software

Mozilla.cz informuje o dvou nových experimentálních funkcích v programu Firefox Test Pilot (zprávička). Snooze Tabs slouží k odkládání panelů na později. Pokud vám někdo pošle odkaz, ale vy nemáte čas si stránku hned přečíst, můžete si naplánovat otevření panelu na později. Stačí kliknout na tlačítko a vybrat, kdy chcete panel otevřít. Firefox panel schová a ve vybraný čas znovu otevře. Pulse umožňuje ohodnotit, jak dobře stránka funguje, např. jak rychle se ve Firefoxu načetla. Podle nasbíraných hodnocení pak bude Mozilla prohlížeč ladit.

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

V Barceloně probíhá veletrh Mobile World Congress 2017. Nokia na něm například představila (360° video na YouTube) novou Nokii 3310 (YouTube). BlackBerry představilo BlackBerry KEYone (YouTube) s QWERTY klávesnicí. LG představilo LG G6 (YouTube). Huawei HUAWEI P10 a P10 Plus. Samsung představil tablet Galaxy Tab S3.

Ladislav Hagara | Komentářů: 1
včera 14:00 | Nová verze

Komunita kolem Linuxu From Scratch (LFS) vydala Linux Linux From Scratch 8.0 a Linux From Scratch 8.0 se systemd. Nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů přichází především s Glibc 2.25 a GCC 6.3.0. Současně bylo oznámeno vydání verze 8.0 knih Beyond Linux From Scratch (BLFS) a Beyond Linux From Scratch se systemd.

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

Byla vydána verze 0.10.0 webového prohlížeče qutebrowser (Wikipedie). Přehled novinek v příspěvku na blogu. Vývojáři qutebrowseru kladou důraz na ovladatelnost pomocí klávesnice a minimální GUI. Inspirovali se prohlížečem dwb a rozšířeními pro Firefox Vimperator a Pentadactyl. Prohlížeč qutebrowser je naprogramován v Pythonu a využívá PyQt5. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GNU GPL 3.

Ladislav Hagara | Komentářů: 25
25.2. 16:22 | Nová verze

Po pěti měsících od vydání Waylandu a Westonu 1.12.0 oznámil Bryce Harrington (Samsung) vydání Waylandu 1.13.0 a Westonu 2.0.0.

Ladislav Hagara | Komentářů: 4
24.2. 13:37 | Bezpečnostní upozornění

Společnost Cloudflare (Wikipedie) na svém blogu potvrdila bezpečnostní problém s její službou. V požadovaných odpovědích od reverzní proxy byla odesílána také data z neinicializované paměti. Útočník tak mohl získat cookies, autentizační tokeny, data posílaná přes HTTP POST a další citlivé informace. Jednalo se o chybu v parsování HTML. Zneužitelná byla od 22. září 2016 do 18. února 2017. Seznam webů, kterých se bezpečnostní problém potenciálně týká na GitHubu.

Ladislav Hagara | Komentářů: 1
24.2. 08:22 | Nová verze

Byla vydána první beta verze Ubuntu 17.04 s kódovým názvem Zesty Zapus. Ke stažení jsou obrazy Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu GNOME, Ubuntu Kylin, Ubuntu Studio a Xubuntu. Dle plánu by Ubuntu 17.04 mělo vyjít 13. dubna 2017.

Ladislav Hagara | Komentářů: 57
23.2. 17:53 | Bezpečnostní upozornění

Google na svém blogu věnovaném počítačové bezpečnost informuje o nalezení "reálného" způsobu generování kolizí hašovací funkce SHA-1. Podrobnosti a zdrojové kódy budou zveřejněny do 90 dnů. Již dnes lze ale na stránce SHAttered nalézt 2 pdf soubory, jejichž obsah se liší a SHA-1 otisk je stejný (infografika).

Ladislav Hagara | Komentářů: 41
23.2. 17:51 | Nová verze

Vyšla nová verzia open source software na správu a automatizáciu cloudových datacentier Danube Cloud 2.4. Danube Cloud je riešenie postavené na SmartOS, ZFS, KVM a zónach. Obsahuje vlastnosti ako integrovaný monitoring, DNS manažment, zálohy, a samozrejme rozsiahlu dokumentáciu.

dano | Komentářů: 15
23.2. 17:46 | Pozvánky

V Plzni se 3. až 5. března 2017 uskuteční AIMTEChackathon. Je to akce pro vývojáře, grafiky, webdesignéry i veřejnost. Akci provází zajímavé přednášky IT odborníků. Více o programu a možnosti přihlášení na stránkách akce.

cuba | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 725 hlasů
 Komentářů: 68, poslední dnes 07:29
    Rozcestník

    Dotaz: JavaScript

    18.8.2009 14:37 Sten Fil | skóre: 4
    JavaScript
    Přečteno: 388×

    Ahoj,

    pri click na element chci zavolat metodu

    OnClick_.

    Nevite jak zjednodusit ten zapis

    .click (...)

    Diky.

     

    function Frm_Login (element)
    {
        $(element).click ( function (frm) {
            return function () { frm.OnClick_(); };
        }(this));

    };

    Frm_Login.prototype.OnClick_ = function ()
    {

         /* Nejake operace. */
    };

     

     

    Odpovědi

    Tarmaq avatar 18.8.2009 15:59 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: JavaScript
    priklad mi prijde dost neotesany, ale minimalne zjednodusit lze zbytecne zanoreni volani do dalsi funkce:
    function Frm_Login (element)
    {
        $(element).click ( function (frm) {
            return frm.OnClick_;
        }(this));
    };
    
    Don't panic!
    18.8.2009 16:47 Sten Fil | skóre: 4
    Rozbalit Rozbalit vše Re: JavaScript

    Zkousim takovou "okenni" aplikaci, ktera by bezela v internetovych prohlizecich.

    Pomoci knihovny dhtmlx vytvarim okna (formulare). Na test treba Frm_Test.

    var okno1 = new Frm_Test ();

    var okno2 = new Frm_Test ();

    A potrebuju aby pri stisku daneho tlacitka na formulari se zavolala metoda

    daneho objektu. Tak mi to prislo podobne jako v desktop aplikacich.

    S JS zacinam takze mozna to je blbost. Uvidim casem.

     

    Tady je cely priklad:




    function Geozone_Frm_Login (ownerWS)
    {
        /**
         * PRIVATE
         */
        var mThis = this;
        var mWin;
        var mCtlLogin;
        var mBtnLogin;
        var mOwnerWS = ownerWS;
       
        /**
         * PROPERTIES
         */
        this.BtnLogin = function () { return mBtnLogin; };
        this.Win = function () { return mWin; };
        this.CtlLogin = function () { return mCtlLogin; };
        this.OwnerWs = function () { return mOwnerWS; };

        /**
         * CONSTRUCTOR
         */   
        /* Vytvorime sebe. dhtmlxWindow. */
        mWin =  MV7.Dhtmlx ().CreateWindow ("FrmLogin" + MV7.UId (), 0, 0, 325, 125, 'Prihlaseni');
       
        /* Prusvitnost. */
        $(mWin).css ({'opacity' : '.90'});
       
        /* Tlacitka formu. */
        mWin.button('close').hide ();
        mWin.button('minmax1').hide ();
        mWin.button('park').hide ();

        /* Umisteni. */
        mWin.denyResize ();
        mWin.center ();
       
        /* Prvek Login */
        mCtlLogin = new Geozone_Ctl_Login ();
        mCtlLogin.Position (5, 5);

        mBtnLogin = new MV7_Widget_Button ('Prihlasit');
        mBtnLogin.Geometry (225, 70, 90, 30);

        $(mBtnLogin.Ele ()).click (function () {
            mThis.BtnLoginOnClick_ ();
        });

        /* Nahozeni prvku na form. */
        mWin.attachObject (mCtlLogin.Ele ());
        mWin.appendObject (mBtnLogin.Ele ());
    };

    Geozone_Frm_Login.prototype.BtnLoginOnClick_ = function ()
    {
        var mThis = this;
       
        this.Win ().progressOn ();
        $(this.BtnLogin ().Ele ()).attr ('disabled', 'disabled');
       
        data = this.CtlLogin ().GetData ();
        MV7.Log ().Trace ('name: ' + data.name + '; pass: ' +data.pass);
       
        this.OwnerWs ().LoginTest (data.name, data.pass,
            function (recv) {
                mThis.LoginTestOnSuccess_ (recv);
            },
            function (obj)
            {
                return function (a, b) {obj.LoginTestOnError_ (a, b); };
            }(this)
           
            );
    /*   
        function (obj)
        {
            return function (recv) { obj.LoginTestOnSuccess_ (recv); };
        }(this),
    */
    };

    /**
     * Volana po uspesnem zavolani WebSluzby Logintest.
     * @param recv
     * @return
     */
    Geozone_Frm_Login.prototype.LoginTestOnSuccess_ = function (recv)
    {
        var res;
       
        res = this.OwnerWs ().LoginTestResult (recv);
       
        MV7.Log ().Trace ('ReturnCode:' + res.ReturnCode);
    };

    Geozone_Frm_Login.prototype.LoginTestOnError_ = function (a, b)
    {
        MV7.Log ().Info ('LoginTestOnError_' + a + b);
    };
     

     

     

    19.8.2009 04:52 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    Na okenni aplikace to chce nejaky toolkit (treba qooxdoo), tento kod vypada podle me strasne:-)
    19.8.2009 10:57 Sten Fil | skóre: 4
    Rozbalit Rozbalit vše Re: JavaScript

    qooxdoo urcite vyzkousim.

    Komplet strasne nebo snad jen nektere konstrukce ? :-)

    19.8.2009 11:34 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    Mi prijde takove neprehledne to vytvareni objektu, a ten objektovy system, ale to je tim, ze jsem zvykly na neco jineho a podle me cistejsiho. Jen se mrkni jak funguje objektovy system v qooxdoo, a uvidis, ze to ma neco do sebe (aspon do cistoty kodu urcite). Neco podobneho, ale velice lightweight jsem napsal v knihovne blite, ale jedna se jen o mini-knihovnu, ktera je vhodna jen na stranky, ne na aplikace (to byl cil).

    Jinak tech frameworku je vic, ja jsem zminil qooxdoo, protoze s nim mam asi rok zkusenosti, a prijde mi to dobre navrzene;)
    19.8.2009 12:38 Sten Fil | skóre: 4
    Rozbalit Rozbalit vše Re: JavaScript

    No mne pripada, ze v JS jde pouzit styl modul (podobne C) i objekt (C++,C#).

    Modul soubor js podobny souboru v C:

    var Modul1 = function() {   
        /* Privatni promenne modulu. */
        var _xx = 0;
        var _xy = null;
        /* Verejne metody. */
        return {
            Metoda1 : function ()
            {
            },
            Metoda2 : function ()
            {
            }
        }
    }();
    V kodu pak volame metody
    Modul1.Metoda1 ().
    Tohle mi pripada dost jasne a funkcni.
     
    Objekt. To je ten muj pokus. Priblizit se k objektum podobnym treba v C++ nebo C# se mi zatim nepodarilo.
    Existuje spoustu knihoven, ktere to nejak implementuji, ale zatim sem tomu moc neporozumel.
    Aby objekt mel sve privatni promenne a metody a verejne prommene a metody a fungovala dedicnost to
    netusim jak udelat. Vzdy je tam nejake ale.

     

     
    19.8.2009 22:40 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    No právě, tento systém je podle mě strašně nepřehledný a na větší projekt se mi to zdá šílené. Příklad vytváření objektů v qooxdoo:
    qx.Class.define("myNamespace.A", {
      // Dědičnost.
      extend: qx.core.Object,
    
      // Konstruktor
      construct: function()
      {
        // Něco jako v jave super(), volání konstruktoru třídy, kterou rozšiřujeme (extend)
        this.base(arguments);
        
        // Něco ...
      },
      members: {
        // metody, v js je všecho jako virtual v C++:)
        tell: function()
        {
          alert("myNamespace.A.tell()");
        }
      }
    });
    
    qx.Class.define("myNamespace.B", {
      // Dědičnost.
      extend: myNamespace.A,
    
      // Konstruktor
      construct: function()
      {
        // Něco jako v jave super(), volání konstruktoru třídy, kterou rozšiřujeme (extend)
        this.base(arguments);
        
        // Něco ...
      },
      members: {
        // no a tady si tu metodu reimplementujeme
        tell: function()
        {
          // zavolá metodu tell z myNamespace.A
          this.base(arguments);
    
          // další kód...
          alert("myNamespace.B.tell()");
        }
      }
    });
    
    Viz dokumentace

    Přijde mi to celkem čisté (na javascript až moc:) ). Qooxdoo umí i interfaces, mixins, properties, události, atd:)
    Tarmaq avatar 19.8.2009 15:58 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: JavaScript

    taky mam s qooxdoo asi dvoulete zkusenosti, neni to uplne spatne, ale jak rikas neni to uplne lightweight.. jinak kdyz jsme migrovali z 0.6.x na 0.7.3 tak to byl docela porod a ted uz je 0.8, do cehoz jsme se radsi ani nepousteli - nase aplikace ma cca 40k radku ;]

    Na ukazku narychlo splacnuta trida:
    qx.Class.define("b.tabview.ButtonFoo",
    {
        extend : qx.ui.pageview.tabview.Button,
    
        construct : function(title)
        {
            this.base(arguments, title);
            this.setAppearance("tab-view-button-Foo");
            this.addEventListener('click', this.bar, this);
        },
        members :
        {
            prop1 : 'OMG',
            foo : function(blah)
            {
                return blah.roflmao();
            },
            bar : function(e)
            {
                alert(e.getTarget().getLabel());
            }
    });
    
    API
    Don't panic!
    19.8.2009 22:44 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    Tak to já jsem něco začal v 0.7.3 a pak migroval na 0.8.0 (později SVN) a migrování proběhlo tím způsobem, že jsem mazal kód. 0.8 řada se mi zdá míň ukecanější (hlavně ty layouty jsou teď lepší, třeba udělat grid layout v 0.7.3 mi dělalo celkem problém). No bylo toho víc, i ten treeview mi teď přijde lepší, a teď nové virtual widgets se mi hodně zamlouvají.

    Ale jak říkáš, qooxdoo je heavy, hodí se podle mě na admin rozhraní, webové aplikace, atd. Na normální webové stránky by to byl overkill (proto jsem napsal bLite).
    20.8.2009 15:58 Andrej Herceg | skóre: 43
    Rozbalit Rozbalit vše Re: JavaScript
    Pred nejakým časom som robil niečo v Ext JS. Keď som potom skúšal qooxdoo, tak mi ten kód vôbec nepripadal prehľadnejší (v porovnaní s tým Ext JS). :)
    21.8.2009 04:12 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    Ext jsem nikdy nezkoušel kvůli licenci, takže nemůžu posoudit :)
    Tarmaq avatar 21.8.2009 12:34 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: JavaScript
    tak tak... ;] ale jinak co jsem koukal na nejaky ukazkovy priklad, tak mi to neprijde prilis odlisne od qooxdoo..
    Don't panic!
    21.8.2009 12:40 Andrej Herceg | skóre: 43
    Rozbalit Rozbalit vše Re: JavaScript
    Ext JS som používal pred zmenou licencie. :)
    21.8.2009 12:49 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: JavaScript
    Tak to vám nezávidím, co s tím teď :)
    mess avatar 21.8.2009 21:19 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: JavaScript
    Neupgradovat :-). Však to bude ještě chvíli držet pohromadě.
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    18.8.2009 16:32 Sten Fil | skóre: 4
    Rozbalit Rozbalit vše Re: JavaScript

    Po precteni clanku na root zdrojak sem to upravil takhle.

    function Frm_Login (element)
    {

        var this_ = this;


        $(element).click ( function () {
            this_.OnClick_();
        });

    };

    Frm_Login.prototype.OnClick_ = function ()
    {

         /* Nejake operace. */
    };

    18.8.2009 19:42 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: JavaScript
    Klíč je v tom, že v JavaScriptu i funkce je hodnota. Takže si s ní můžete házet jak chcete: přiřazovat do proměnné, předávat jiné funkci jako parametr a tak.

    Takže i
    $(element).click ( function () {
      this_.OnClick_();
    });
    by mělo jít ještě trochu zjednodušit, asi tak na
    $(element).click ( this_.OnClick_ );
    To vyplývá z toho, jak v jQuery funguje click: jako parametr dostane funkci, kterou zavolá při kliknutí na element. V původní variantě vytváříte anonymní funkci, která teprve zavolá tu, co chcete. Ale protože nic jiného se v ní nedělá, můžete funkci click předat rovnou tu funkci, kterou potřebujete zavolat.
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    18.8.2009 21:02 Sten Fil
    Rozbalit Rozbalit vše Re: JavaScript

     

    Dik za info.
    Takhle mi to nejak nefunguje. Spoustim na FF 3.0 na debian.
    $(element).click ( this_.OnClick_ );
    Problem je v tom, ze v OnClick_ volam metody objektu viz. cely priklad nahore.
    A v te metode OnClick_ je v tomto pripade this = elementu na kterem udalost nastala.

     

    18.8.2009 23:38 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: JavaScript
    Máte samozřejmě pravdu, jQuery s this trochu šaškuje, jak já v tom pravidelně nepracuju a znám to jenom povrchně, tak jsem na to zapomněl. Ale na principu to nic nemění.
    Ještě na tom nejsem tak špatně, abych četl Viewegha.

    Založit nové vláknoNahoru

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

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