[TL;DR verziu: používanie cookies k ukladaniu výsledky asynchrónne volania; vykreslenie Výsledky posledných asynchrónne volania okamžite a potom overiť po načítaní stránky.]
Bol som pracoval na intranetovej lokalite SharePoint pre klienta, že funkcie, okrem iného, štylizované druhej navigácii ktorého menu voľby sú riadené prostredníctvom pravidelnej starými vlastného zoznamu. Myšlienka je, že klient dostane kontrolovať "ich" stránky menu bez ovplyvnenia alebo byť zasiahnuté globálnej navigácie vyháňaní to.
(tam je niečo neuveriteľne podvratné pridávanie CEWP, ktorý odkazuje na súbor HTML, ktorý načíta niektoré CSS a JS zásadne zmeniť takmer všetko o webe správanie... ale to je iný post)
Kód pre tento veľmi jednoduchý:
- Čakať na stránku až do konca nakládky a asynchrónne volanie naložiť menu položky zoznamu pomocou odpočinku alebo lists.asmx alebo čokoľvek, aby
- Pomocou jQuery, dynamicky naplniť veľa Ak <li>je vnútri rodič <ul> (Pozri kresťanskej Pinder článok tu pre zjednodušené vysvetlenie tohto tecnnique)
- Použitie CSS robiť všetko formátovanie
- Zisk!
Boľavé miesto tu je, že zakaždým, keď niekto udrie jedným zo stránky, používateľa webového prehliadača je osloviť načítať položky zo zoznamu. Po dokončení sa dev a testovanie ukázalo veci byť stabilnejší a kompletné, Táto výzva je zbytočné viac ako 99% doby, kedy v ponuke zriedka to zmení. Má tiež podivné UI ovplyvniť, čo je bežné v tomto odvážnom novom svete hyper-AJAX webových stránok – stránky omietky a až potom v ponuke vykresliť. Je nervózna a rušivé podľa môjho názoru. A nervózny. Takže, ukladanie do vyrovnávacej pamäte.
Som upravil logika thusly:
- Pohľad na cookie v prehliadači, ktorý obsahuje ponuku ako som naposledy čítal
- Ak sa našiel, robí to okamžite. Nemusíte čakať na dokončenie načítania stránky. (Budete musieť uistite sa, že HTML je strategicky umiestnené tu., ale to nie je ťažké urobiť).
- Čakať na stránku až do konca nakládky a asynchrónne volanie naložiť menu položky zoznamu pomocou odpočinku alebo lists.asmx alebo čokoľvek, aby
- Porovnajte čo mám proti cookie
- Ak sa to zhoduje, zastaviť
- Inak, pomocou jQuery, dynamicky naplniť veľa Ak <li>je v <ul>
- Použitie CSS robiť všetko formátovanie
- Zisk!
Niektoré z vás chcel povedať, "Hej! Neexistuje žiadny skutočný caching deje pretože čítate menu rovnako každý jednotlivý čas.” A máš pravdu-nejsem dáva server akýkoľvek druh prestávku. Ale pretože hovor je asynchrónna a stane po stránke počiatočné zaťaženie HTML plne omietky, "Pripadá mi to" lepšie reagovať na užívateľa. V ponuke omietky docela ako stránku čerpá. Ak v ponuke dôjde k zmene, používateľ sa podrobí nervózny znovu čerpať z menu, ale iba tento raz.
Existuje niekoľko spôsobov na zefektívnenie tejto cache a pomoct server v rovnakom čase:
- Zaviesť pravidlo, že "cookie cache" je platný pre minimálne 24 hodín, alebo nejaký iný Časový. Pokiaľ neexistuje žiadna cookie vypršala, použitie cookie ponuky snímka a nikdy hit server.
No... to je všetko, čo príde na myseľ hneď :).
Ak má niekto nejaké chytré nápady tu by chcel poznať.
A napokon – Táto technika môže byť použitá pre iné veci. Tento klient strana má mnoho vecí, data-riadený na rôznych stránkach, Mnohé z nich mení pomerne zriedka (ako raz týždenne alebo raz za mesiac). Ak cielite špecifické oblasti funkčnosti, si môžete dať citlivejšie UI ťahom obsah z miestnej cookie obchodu a vykresľovanie okamžite. Pripadá mi to rýchlejšie pre užívateľa aj ak nie ukladáte server bez cyklov. Ste môžete uložiť na server cykly pri rozhodovaní o niektorých podmienkach a spúšťa zruší tento miestnej cookie cache. To je všetky situačná a diletantský veci a naozaj najviac zábavy :).
</koniec>
Nasledujte ma na stebėtų na http://www.twitter.com/pagalvin
Ahoj Pavla,
Pekné prevedenie, to je niečo, čo môžeme používať, ale sme použili HTML5 miestneho ukladacieho priestoru API miesto cookies. Prvý disk bol, že sme potrebovali viac ako cookie umožňujú ukladať. Ale Ďalšou výhodou je, že to nezvýši náklad, keďže detailnΘ a späť. Z hľadiska dev je veľmi jednoduché použitie.
Podpora prehľadávača nie je dokonalý ale úprimne dosť dobré, http://caniuse.com/namevalue-storage .
Jonathan