ue Insights into energy transfer pathways between the exciplex host and fluorescent guest: attaining highly efficient 710 nm electroluminescence By pubs.rsc.org Published On :: J. Mater. Chem. C, 2020, 8,5704-5714DOI: 10.1039/D0TC00986E, PaperChun-Ying Huang, Ssu-Yu Ho, Chien-Hsun Lai, Chang-Lun Ko, Yu-Chen Wei, Jia-An Lin, Deng-Gao Chen, Tzu-Yu Ko, Ken-Tsung Wong, Zhiyun Zhang, Wen-Yi Hung, Pi-Tai ChouInsight has been gained into the energy transfer pathways between the exciplex host and NIR fluorescence chromophores.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue tert-Butyl substituted hetero-donor TADF compounds for efficient solution-processed non-doped blue OLEDs By pubs.rsc.org Published On :: J. Mater. Chem. C, 2020, 8,5769-5776DOI: 10.1039/D0TC00718H, PaperFeng-Ming Xie, Zhi-Dong An, Miao Xie, Yan-Qing Li, Guang-Hui Zhang, Shi-Jie Zou, Li Chen, Jing-De Chen, Tao Cheng, Jian-Xin TangSolution-processed non-doped blue and white OLEDs with record-high EQEs of 25.8% and 27.3% are realized with a hetero-donor tert-butyl substitution strategy.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Benzonitrile and dicyanocarbazole derived electron transport type host materials for improved device lifetime in blue thermally activated delayed fluorescent organic light-emitting diodes By pubs.rsc.org Published On :: J. Mater. Chem. C, 2020, 8,5832-5838DOI: 10.1039/C9TC06978J, PaperSung Yong Byeon, Kyung Hyung Lee, Jun Yeob LeeThe electron transport host materials derived from dibenzofuran, benzonitrile and dicyanocarbazole units showed high triplet energy above 3.0 eV, high efficiency over 20% and 31 h lifetime up to 75% of initial luminance at 500 cd m−2.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Phase control for quasi-2D blue emitters by spacer cation engineering By pubs.rsc.org Published On :: J. Mater. Chem. C, 2020, Accepted ManuscriptDOI: 10.1039/D0TC01631D, PaperHo Won Tam, Tik Lun Leung, Wenting Sun, Fangzhou Liu, Chao Ma, Chun Sing Kam, Ivor Lončarić, Luca Grisanti, Juraj Ovčar, Željko Skoko, Jasminka Popović, Aleksandra DjurisicEffect of the alkylammonium tail length in phenyl-alkyl spacer cations in quasi-2D Ruddlesden-Popper perovskites on the phase distribution in low n films (n=2 stoichiometry) is investigated. The increase in the...The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Nepantla: an anthology for queer poets of color / edited by Christopher Soto By library.mit.edu Published On :: Sun, 23 Feb 2020 07:00:06 EST Barker Library - PS591.G38 N472 2018 Full Article
ue Steel crow saga / Paul Krueger By library.mit.edu Published On :: Sun, 1 Mar 2020 06:44:42 EST Dewey Library - PS3611.R843 S74 2019 Full Article
ue Mary Toft; or, the rabbit queen: a novel / Dexter Palmer By library.mit.edu Published On :: Sun, 12 Apr 2020 07:12:59 EDT Dewey Library - PS3616.A33885 M37 2019 Full Article
ue Afro-fabulations: the queer drama of Black life / Tavia Nyong'o By library.mit.edu Published On :: Sun, 26 Apr 2020 07:06:33 EDT Barker Library - PS338.N4 O25 2019 Full Article
ue Letters from Amherst: five narrative letters / Samuel R. Delany By library.mit.edu Published On :: Sun, 26 Apr 2020 07:06:33 EDT Dewey Library - PS3554.E437 Z48 2019 Full Article
ue Inscrutable belongings: queer Asian North American fiction / Stephen Hong Sohn By library.mit.edu Published On :: Sun, 26 Apr 2020 07:06:33 EDT Hayden Library - PS153.G38 S64 2018 Full Article
ue Post-borderlandia: Chicana literature and gender variant critique / T. Jackie Cuevas By library.mit.edu Published On :: Sun, 26 Apr 2020 07:06:33 EDT Hayden Library - PS153.M4 C84 2018 Full Article
ue Parisian lives: Samuel Beckett, Simone de Beauvoir, and me: a memoir / Deirdre Bair By library.mit.edu Published On :: Sun, 3 May 2020 07:23:24 EDT Dewey Library - PS3602.A5635 Z46 2019 Full Article
ue La France vue du ciel - Extrait : Saint-Cirq-Lapopie et Rocamadour By www.la-france-vue-du-ciel.fr Published On :: Tue, 28 Nov 2006 17:45:00 +0100 Sylvain Augier nous invite à découvrir depuis un hélicoptère l’incroyable richesse et la beauté des paysages et monuments de France. Un point de vue unique pour capturer des images sublimes et inédites. Une merveilleuse aventure humaine ! Full Article
ue La France vue du ciel - Extrait : Les Citadelles du pays Cathare By www.la-france-vue-du-ciel.fr Published On :: Tue, 28 Nov 2006 17:46:00 +0100 Sylvain Augier nous invite à découvrir depuis un hélicoptère l’incroyable richesse et la beauté des paysages et monuments de France. Un point de vue unique pour capturer des images sublimes et inédites. Une merveilleuse aventure humaine ! Full Article
ue La France vue du ciel - Extrait : Les Châteaux d’Azay-le-Rideau et de Chinon By www.la-france-vue-du-ciel.fr Published On :: Tue, 28 Nov 2006 17:47:00 +0100 Sylvain Augier nous invite à découvrir depuis un hélicoptère l’incroyable richesse et la beauté des paysages et monuments de France. Un point de vue unique pour capturer des images sublimes et inédites. Une merveilleuse aventure humaine ! Full Article
ue La France vue du ciel - Extrait : L’Aiguille du Midi By www.la-france-vue-du-ciel.fr Published On :: Tue, 28 Nov 2006 17:48:00 +0100 Sylvain Augier nous invite à découvrir depuis un hélicoptère l’incroyable richesse et la beauté des paysages et monuments de France. Un point de vue unique pour capturer des images sublimes et inédites. Une merveilleuse aventure humaine ! Full Article
ue La France vue du ciel - Extrait : complément du DVD By www.la-france-vue-du-ciel.fr Published On :: Tue, 28 Nov 2006 17:49:00 +0100 Complément du DVDSylvain Augier nous invite à découvrir depuis un hélicoptère l’incroyable richesse et la beauté des paysages et monuments de France. Un point de vue unique pour capturer des images sublimes et inédites. Une merveilleuse aventure humaine ! Full Article
ue Recent findings in intelligent computing techniques: proceedings of the 5th ICACNI 2017. / Pankaj Kumar Sa, Sambit Bakshi, Ioannis K. Hatzilygeroudis, Manmath Narayan Sahoo, editors By library.mit.edu Published On :: Sun, 29 Mar 2020 06:19:37 EDT Online Resource Full Article
ue Optimization based model using fuzzy and other statistical techniques towards environmental sustainability Samsul Ariffin Abdul Karim, Evizal Abdul Kadir, Arbi Haza Nasution, editors By library.mit.edu Published On :: Sun, 5 Apr 2020 06:19:51 EDT Online Resource Full Article
ue Internet of Things, a confluence of many disciplines: Second IFIP International Cross-Domain Conference, IFIPIoT 2019, Tampa, FL, USA, October 31 - November 1, 2019, revised selected papers / Augusto Casaca, Srinivas Katkoori, Sandip Ray, Leon Strous (eds By library.mit.edu Published On :: Sun, 26 Apr 2020 06:32:35 EDT Online Resource Full Article
ue Paris blues / director, Martin Ritt By library.mit.edu Published On :: Sun, 2 Oct 2016 06:20:14 EDT Browsery DVD PN1997.P37 2014 Full Article
ue Hommage de l'Orchestre philharmonique de Radio France à Myung-Whun Chung / une production Bel Air Media, Les Chorégies d'Orange, Radio France avec la participation de France Télévisions, Mezzo et le soutien de Centre national By library.mit.edu Published On :: Sun, 30 Jul 2017 06:23:01 EDT Browsery DVD C4724 hom Full Article
ue Tatiana / a ballet by John Neumeier ; after "Eugene Onegin" by Alexander Pushkin ; music by Lera Auerbach ; choreography, staging, sets, lighting, John Neumeier ; Hamburg Ballet-John Neumeier ; a co-production by Hamburgische Staatsoper GmbH/Ha By library.mit.edu Published On :: Sun, 30 Jul 2017 06:23:01 EDT Browsery DVD Au34 tat Full Article
ue Turandot: dramma lirico in tre atti e cinque quadri / libretto di Giuseppe Adami e Renato Simoni ; musica di Giacomo Puccini ; completamento del terzo atto di Luciano Berio ; RAI, Teatro alla Scala presentano La Scala per Expo dal Teatro alla Scala di Mil By library.mit.edu Published On :: Sun, 22 Apr 2018 06:20:56 EDT Browsery DVD P961 tur c Full Article
ue Rodgers & Hammerstein's Carousel / music by Richard Rodgers ; book and lyrics by Oscar Hammerstein II ; based on Ferenc Molnár's play "Lilion," adapted by Chad Beguelin ; directed for the stage by John Rando ; directed by by Gl By library.mit.edu Published On :: Sun, 17 Jun 2018 06:28:17 EDT Browsery DVD M1500.R63 C3 2017 Full Article
ue [ASAP] Substituent Optimization of (1 ? 2)-Glucopyranan for Tough, Strong, and Highly Stretchable Film with Dynamic Interchain Interactions By feedproxy.google.com Published On :: Fri, 01 May 2020 04:00:00 GMT ACS Macro LettersDOI: 10.1021/acsmacrolett.0c00266 Full Article
ue FONS SIGNATUS ... SEU VII. LYTANIAE DE VENERABILI, ET AUGUSTISSIMO ALTARIS SACRAMENTO Quarum primae quinque Solenniores, Ultimae Duae minùs Solennes, Omnes tamen non nimis longae, Per Annum secundùm consuetudinem locorum, ... Unà cum Cantic By reader.digitale-sammlungen.de Published On :: Mon, 27 Apr 2020 13:12:02 +0100 Autor: Münster, Joseph Joachim Benedikt, 1694-1751 Erschienen 1751 BSB-Signatur 4 Mus.pr. 44603 URN: urn:nbn:de:bvb:12-bsb11148808-2 URL: http://reader.digitale-sammlungen.de/de/fs1/object/display/bsb11148808_00001.html/ Full Article
ue Revue musicale coll. de morceaux faciles pour piano et violon ou flûte sur des thêmes favoris ; op. 305 By reader.digitale-sammlungen.de Published On :: Mon, 27 Apr 2020 13:12:02 +0100 Autor: Küffner, Joseph, 1776-1856 Erschienen 1846 BSB-Signatur 4 Mus.pr. 92.644-14/23 URN: urn:nbn:de:bvb:12-bsb11138730-5 URL: http://reader.digitale-sammlungen.de/de/fs1/object/display/bsb11138730_00001.html/ Full Article
ue Revue musicale coll. de morceaux faciles pour piano et violon ou flûte sur des thêmes favoris ; op. 305 By reader.digitale-sammlungen.de Published On :: Mon, 27 Apr 2020 13:12:02 +0100 Autor: Küffner, Joseph, 1776-1856 Erschienen 1847 BSB-Signatur 4 Mus.pr. 92.644-14/23 URN: urn:nbn:de:bvb:12-bsb11138732-6 URL: http://reader.digitale-sammlungen.de/de/fs1/object/display/bsb11138732_00001.html/ Full Article
ue Potpourri ou choix d'airs, romances et marches tirées des opéra Allemandes et Italiennes les plus applaudis arrangées pour la guitarre avec accompagnement d'une flûte ou violon ; oeuvre périodique By reader.digitale-sammlungen.de Published On :: Tue, 28 Apr 2020 13:12:02 +0100 Autor: Call, Leonhard von, 1767-1815 Erschienen 1810 BSB-Signatur 4 Mus.pr. 2011.2792 URN: urn:nbn:de:bvb:12-bsb11142493-8 URL: http://reader.digitale-sammlungen.de/de/fs1/object/display/bsb11142493_00001.html/ Full Article
ue Visualization of materials using the confocal laser scanning microscopy technique By feeds.rsc.org Published On :: Chem. Soc. Rev., 2020, 49,2408-2425DOI: 10.1039/C8CS00061A, Review ArticleXu Teng, Feng Li, Chao LuThis review summarizes the recent applications of confocal laser scanning microscopy in materials science.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Supramolecular prodrugs based on host–guest interactions By feeds.rsc.org Published On :: Chem. Soc. Rev., 2020, 49,2303-2315DOI: 10.1039/C9CS00622B, Tutorial ReviewWen-Chao Geng, Jonathan L. Sessler, Dong-Sheng GuoThe concept, detailed progress, advantages and opportunities of supramolecular drugs via host–guest chemistry are summarized.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Influence of nanomedicine mechanical properties on tumor targeting delivery By feeds.rsc.org Published On :: Chem. Soc. Rev., 2020, 49,2273-2290DOI: 10.1039/C9CS00575G, Tutorial ReviewZheng Li, Chen Xiao, Tuying Yong, Zifu Li, Lu Gan, Xiangliang YangThis tutorial review summarizes the influence of nanomedicine mechanical properties on drug delivery efficiency, antitumor efficacy and safety.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Atomically dispersed metal–nitrogen–carbon catalysts for fuel cells: advances in catalyst design, electrode performance, and durability improvement By feeds.rsc.org Published On :: Chem. Soc. Rev., 2020, Advance ArticleDOI: 10.1039/C9CS00903E, Review ArticleYanghua He, Shengwen Liu, Cameron Priest, Qiurong Shi, Gang WuThe review provides a comprehensive understanding of the atomically dispersed metal–nitrogen–carbon cathode catalysts for proton-exchange membrane fuel cell applications.To cite this article before page numbers are assigned, use the DOI form of citation above.The content of this RSS Feed (c) The Royal Society of Chemistry Full Article
ue Wing Chun (1994) / directed by Yuen Woo-Ping [DVD]. By encore.st-andrews.ac.uk Published On :: [China] : Modern Audio International, [2005] Full Article
ue So close (2002) / directed by Corey Yuen [DVD]. By encore.st-andrews.ac.uk Published On :: [U.S.A.] : Columbia Tri-Star Home Entertainment, [2003] Full Article
ue Mary Queen of Scots (2018) / directed by Josie Rourke [DVD]. By encore.st-andrews.ac.uk Published On :: [U.K.] : Universal Pictures Home Entertainment, [2019] Full Article
ue Magnificent butcher (1978) / directed by Yuen Woo-Ping [DVD]. By encore.st-andrews.ac.uk Published On :: [U.S.A.] : Twentieth Century Fox Home Entertainment, [2003] Full Article
ue Iron monkey (1993) / directed by Yuen Woo-Ping [DVD]. By encore.st-andrews.ac.uk Published On :: [Taiwan] : Bonsai Media Corporation, [2008] Full Article
ue The insult (2017) / written and directed by Ziad Doueiri [DVD]. By encore.st-andrews.ac.uk Published On :: [U.S.A.] : Cohen Media Group, [2018] Full Article
ue Hitlerjunge Quex (1933) / directed by Hans Steinhoff [DVD]. By encore.st-andrews.ac.uk Published On :: [Germany] : International Historic Films Inc., [2007] Full Article
ue The hateful eight (2015) / written and directed by Quentin Taratino [DVD]. By encore.st-andrews.ac.uk Published On :: [U.K.] : Entertainment in Video, [2016] Full Article
ue Blue is the warmest colour (2013) / written and directed by Abdellatif Kechiches [DVD]. By encore.st-andrews.ac.uk Published On :: [U.K.] : Artifical Eye, [2014] Full Article
ue Trailer for “Navy Blue” By news.guernicaeditions.com Published On :: Fri, 26 Feb 2016 17:00:50 +0000 We’re excited to announce the trailer for Steve Meagher’s Navy Blue! Broken hymns. Desperate prayers. Tales of first heroes. Stories of the street. The poems in Navy Blue walk the middle ground between sorrow and salvation, tackling themes of devotion, regret, innocence lost and mortality through an array of dark landscapes and narratives of the dispossessed. Written in […] Full Article News Poetry book trailers First Poets Series Navy Blue Steve Meagher
ue David Huebert Wins the CBC Short Story Competition By news.guernicaeditions.com Published On :: Fri, 22 Apr 2016 16:55:59 +0000 Congratulations to David Huebert, the winner of this year’s CBC Short Story Prize! David won this year’s short story competition with a story entitled “Enigma”, which is about a woman who must end the life of her beloved horse. As he explains in a recent article by David Burke, the idea for the story came […] Full Article Awards Contests Fiction News CBC Short Story Competition David Huebert Enigma We are no longer the smart kids in class
ue Request with Intent: Caching Strategies in the Age of PWAs By feedproxy.google.com Published On :: 2019-11-21T14:30:06+00:00 Once upon a time, we relied on browsers to handle caching for us; as developers in those days, we had very little control. But then came Progressive Web Apps (PWAs), Service Workers, and the Cache API—and suddenly we have expansive power over what gets put in the cache and how it gets put there. We can now cache everything we want to… and therein lies a potential problem. Media files—especially images—make up the bulk of average page weight these days, and it’s getting worse. In order to improve performance, it’s tempting to cache as much of this content as possible, but should we? In most cases, no. Even with all this newfangled technology at our fingertips, great performance still hinges on a simple rule: request only what you need and make each request as small as possible. To provide the best possible experience for our users without abusing their network connection or their hard drive, it’s time to put a spin on some classic best practices, experiment with media caching strategies, and play around with a few Cache API tricks that Service Workers have hidden up their sleeves. Best intentions All those lessons we learned optimizing web pages for dial-up became super-useful again when mobile took off, and they continue to be applicable in the work we do for a global audience today. Unreliable or high latency network connections are still the norm in many parts of the world, reminding us that it’s never safe to assume a technical baseline lifts evenly or in sync with its corresponding cutting edge. And that’s the thing about performance best practices: history has borne out that approaches that are good for performance now will continue being good for performance in the future. Before the advent of Service Workers, we could provide some instructions to browsers with respect to how long they should cache a particular resource, but that was about it. Documents and assets downloaded to a user’s machine would be dropped into a directory on their hard drive. When the browser assembled a request for a particular document or asset, it would peek in the cache first to see if it already had what it needed to possibly avoid hitting the network. We have considerably more control over network requests and the cache these days, but that doesn’t excuse us from being thoughtful about the resources on our web pages. Request only what you need As I mentioned, the web today is lousy with media. Images and videos have become a dominant means of communication. They may convert well when it comes to sales and marketing, but they are hardly performant when it comes to download and rendering speed. With this in mind, each and every image (and video, etc.) should have to fight for its place on the page. A few years back, a recipe of mine was included in a newspaper story on cooking with spirits (alcohol, not ghosts). I don’t subscribe to the print version of that paper, so when the article came out I went to the site to take a look at how it turned out. During a recent redesign, the site had decided to load all articles into a nearly full-screen modal viewbox layered on top of their homepage. This meant requesting the article required requests for all of the assets associated with the article page plus all the contents and assets for the homepage. Oh, and the homepage had video ads—plural. And, yes, they auto-played. I popped open DevTools and discovered the page had blown past 15 MB in page weight. Tim Kadlec had recently launched What Does My Site Cost?, so I decided to check out the damage. Turns out that the actual cost to view that page for the average US-based user was more than the cost of the print version of that day’s newspaper. That’s just messed up. Sure, I could blame the folks who built the site for doing their readers such a disservice, but the reality is that none of us go to work with the goal of worsening our users’ experiences. This could happen to any of us. We could spend days scrutinizing the performance of a page only to have some committee decide to set that carefully crafted page atop a Times Square of auto-playing video ads. Imagine how much worse things would be if we were stacking two abysmally-performing pages on top of each other! Media can be great for drawing attention when competition is high (e.g., on the homepage of a newspaper), but when you want readers to focus on a single task (e.g., reading the actual article), its value can drop from important to “nice to have.” Yes, studies have shown that images excel at drawing eyeballs, but once a visitor is on the article page, no one cares; we’re just making it take longer to download and more expensive to access. The situation only gets worse as we shove more media into the page. We must do everything in our power to reduce the weight of our pages, so avoid requests for things that don’t add value. For starters, if you’re writing an article about a data breach, resist the urge to include that ridiculous stock photo of some random dude in a hoodie typing on a computer in a very dark room. Request the smallest file you can Now that we’ve taken stock of what we do need to include, we must ask ourselves a critical question: How can we deliver it in the fastest way possible? This can be as simple as choosing the most appropriate image format for the content presented (and optimizing the heck out of it) or as complex as recreating assets entirely (for example, if switching from raster to vector imagery would be more efficient). Offer alternate formats When it comes to image formats, we don’t have to choose between performance and reach anymore. We can provide multiple options and let the browser decide which one to use, based on what it can handle. You can accomplish this by offering multiple sources within a picture or video element. Start by creating multiple formats of the media asset. For example, with WebP and JPG, it’s likely that the WebP will have a smaller file size than the JPG (but check to make sure). With those alternate sources, you can drop them into a picture like this: <picture> <source srcset="my.webp" type="image/webp"> <img src="my.jpg" alt="Descriptive text about the picture."> </picture> Browsers that recognize the picture element will check the source element before making a decision about which image to request. If the browser supports the MIME type “image/webp,” it will kick off a request for the WebP format image. If not (or if the browser doesn’t recognize picture), it will request the JPG. The nice thing about this approach is that you’re serving the smallest image possible to the user without having to resort to any sort of JavaScript hackery. You can take the same approach with video files: <video controls> <source src="my.webm" type="video/webm"> <source src="my.mp4" type="video/mp4"> <p>Your browser doesn’t support native video playback, but you can <a href="my.mp4" download>download</a> this video instead.</p> </video> Browsers that support WebM will request the first source, whereas browsers that don’t—but do understand MP4 videos—will request the second one. Browsers that don’t support the video element will fall back to the paragraph about downloading the file. The order of your source elements matters. Browsers will choose the first usable source, so if you specify an optimized alternative format after a more widely compatible one, the alternative format may never get picked up. Depending on your situation, you might consider bypassing this markup-based approach and handle things on the server instead. For example, if a JPG is being requested and the browser supports WebP (which is indicated in the Accept header), there’s nothing stopping you from replying with a WebP version of the resource. In fact, some CDN services—Cloudinary, for instance—come with this sort of functionality right out of the box. Offer different sizes Formats aside, you may want to deliver alternate image sizes optimized for the current size of the browser’s viewport. After all, there’s no point loading an image that’s 3–4 times larger than the screen rendering it; that’s just wasting bandwidth. This is where responsive images come in. Here’s an example: <img src="medium.jpg" srcset="small.jpg 256w, medium.jpg 512w, large.jpg 1024w" sizes="(min-width: 30em) 30em, 100vw" alt="Descriptive text about the picture."> There’s a lot going on in this super-charged img element, so I’ll break it down: This img offers three size options for a given JPG: 256 px wide (small.jpg), 512 px wide (medium.jpg), and 1024 px wide (large.jpg). These are provided in the srcset attribute with corresponding width descriptors.The src defines a default image source, which acts as a fallback for browsers that don’t support srcset. Your choice for the default image will likely depend on the context and general usage patterns. Often I’d recommend the smallest image be the default, but if the majority of your traffic is on older desktop browsers, you might want to go with the medium-sized image.The sizes attribute is a presentational hint that informs the browser how the image will be rendered in different scenarios (its extrinsic size) once CSS has been applied. This particular example says that the image will be the full width of the viewport (100vw) until the viewport reaches 30 em in width (min-width: 30em), at which point the image will be 30 em wide. You can make the sizes value as complicated or as simple as you want; omitting it causes browsers to use the default value of 100vw. You can even combine this approach with alternate formats and crops within a single picture. ???? All of this is to say that you have a number of tools at your disposal for delivering fast-loading media, so use them! Defer requests (when possible) Years ago, Internet Explorer 11 introduced a new attribute that enabled developers to de-prioritize specific img elements to speed up page rendering: lazyload. That attribute never went anywhere, standards-wise, but it was a solid attempt to defer image loading until images are in view (or close to it) without having to involve JavaScript. There have been countless JavaScript-based implementations of lazy loading images since then, but recently Google also took a stab at a more declarative approach, using a different attribute: loading. The loading attribute supports three values (“auto,” “lazy,” and “eager”) to define how a resource should be brought in. For our purposes, the “lazy” value is the most interesting because it defers loading the resource until it reaches a calculated distance from the viewport. Adding that into the mix… <img src="medium.jpg" srcset="small.jpg 256w, medium.jpg 512w, large.jpg 1024w" sizes="(min-width: 30em) 30em, 100vw" loading="lazy" alt="Descriptive text about the picture."> This attribute offers a bit of a performance boost in Chromium-based browsers. Hopefully it will become a standard and get picked up by other browsers in the future, but in the meantime there’s no harm in including it because browsers that don’t understand the attribute will simply ignore it. This approach complements a media prioritization strategy really well, but before I get to that, I want to take a closer look at Service Workers. Manipulate requests in a Service Worker Service Workers are a special type of Web Worker with the ability to intercept, modify, and respond to all network requests via the Fetch API. They also have access to the Cache API, as well as other asynchronous client-side data stores like IndexedDB for resource storage. When a Service Worker is installed, you can hook into that event and prime the cache with resources you want to use later. Many folks use this opportunity to squirrel away copies of global assets, including styles, scripts, logos, and the like, but you can also use it to cache images for use when network requests fail. Keep a fallback image in your back pocket Assuming you want to use a fallback in more than one networking recipe, you can set up a named function that will respond with that resource: function respondWithFallbackImage() { return caches.match( "/i/fallbacks/offline.svg" ); } Then, within a fetch event handler, you can use that function to provide that fallback image when requests for images fail at the network: self.addEventListener( "fetch", event => { const request = event.request; if ( request.headers.get("Accept").includes("image") ) { event.respondWith( return fetch( request, { mode: 'no-cors' } ) .then( response => { return response; }) .catch( respondWithFallbackImage ); ); } }); When the network is available, users get the expected behavior: Social media avatars are rendered as expected when the network is available. But when the network is interrupted, images will be swapped automatically for a fallback, and the user experience is still acceptable: A generic fallback avatar is rendered when the network is unavailable. On the surface, this approach may not seem all that helpful in terms of performance since you’ve essentially added an additional image download into the mix. With this system in place, however, some pretty amazing opportunities open up to you. Respect a user’s choice to save data Some users reduce their data consumption by entering a “lite” mode or turning on a “data saver” feature. When this happens, browsers will often send a Save-Data header with their network requests. Within your Service Worker, you can look for this header and adjust your responses accordingly. First, you look for the header: let save_data = false; if ( 'connection' in navigator ) { save_data = navigator.connection.saveData; } Then, within your fetch handler for images, you might choose to preemptively respond with the fallback image instead of going to the network at all: self.addEventListener( "fetch", event => { const request = event.request; if ( request.headers.get("Accept").includes("image") ) { event.respondWith( if ( save_data ) { return respondWithFallbackImage(); } // code you saw previously ); } }); You could even take this a step further and tune respondWithFallbackImage() to provide alternate images based on what the original request was for. To do that you’d define several fallbacks globally in the Service Worker: const fallback_avatar = "/i/fallbacks/avatar.svg", fallback_image = "/i/fallbacks/image.svg"; Both of those files should then be cached during the Service Worker install event: return cache.addAll( [ fallback_avatar, fallback_image ]); Finally, within respondWithFallbackImage() you could serve up the appropriate image based on the URL being fetched. In my site, the avatars are pulled from Webmention.io, so I test for that. function respondWithFallbackImage( url ) { const image = avatars.test( /webmention.io/ ) ? fallback_avatar : fallback_image; return caches.match( image ); } With that change, I’ll need to update the fetch handler to pass in request.url as an argument to respondWithFallbackImage(). Once that’s done, when the network gets interrupted I end up seeing something like this: A webmention that contains both an avatar and an embedded image will render with two different fallbacks when the Save-Data header is present. Next, we need to establish some general guidelines for handling media assets—based on the situation, of course. The caching strategy: prioritize certain media In my experience, media—especially images—on the web tend to fall into three categories of necessity. At one end of the spectrum are elements that don’t add meaningful value. At the other end of the spectrum are critical assets that do add value, such as charts and graphs that are essential to understanding the surrounding content. Somewhere in the middle are what I would call “nice-to-have” media. They do add value to the core experience of a page but are not critical to understanding the content. If you consider your media with this division in mind, you can establish some general guidelines for handling each, based on the situation. In other words, a caching strategy. Media loading strategy, broken down by how critical an asset is to understanding an interface Media category Fast connection Save-Data Slow connection No network Critical Load media Replace with placeholder Nice-to-have Load media Replace with placeholder Non-critical Remove from content entirely When it comes to disambiguating the critical from the nice-to-have, it’s helpful to have those resources organized into separate directories (or similar). That way we can add some logic into the Service Worker that can help it decide which is which. For example, on my own personal site, critical images are either self-hosted or come from the website for my book. Knowing that, I can write regular expressions that match those domains: const high_priority = [ /aaron-gustafson.com/, /adaptivewebdesign.info/ ]; With that high_priority variable defined, I can create a function that will let me know if a given image request (for example) is a high priority request or not: function isHighPriority( url ) { // how many high priority links are we dealing with? let i = high_priority.length; // loop through each while ( i-- ) { // does the request URL match this regular expression? if ( high_priority[i].test( url ) ) { // yes, it’s a high priority request return true; } } // no matches, not high priority return false; } Adding support for prioritizing media requests only requires adding a new conditional into the fetch event handler, like we did with Save-Data. Your specific recipe for network and cache handling will likely differ, but here was how I chose to mix in this logic within image requests: // Check the cache first // Return the cached image if we have one // If the image is not in the cache, continue // Is this image high priority? if ( isHighPriority( url ) ) { // Fetch the image // If the fetch succeeds, save a copy in the cache // If not, respond with an "offline" placeholder // Not high priority } else { // Should I save data? if ( save_data ) { // Respond with a "saving data" placeholder // Not saving data } else { // Fetch the image // If the fetch succeeds, save a copy in the cache // If not, respond with an "offline" placeholder } } We can apply this prioritized approach to many kinds of assets. We could even use it to control which pages are served cache-first vs. network-first. Keep the cache tidy The ability to control which resources are cached to disk is a huge opportunity, but it also carries with it an equally huge responsibility not to abuse it. Every caching strategy is likely to differ, at least a little bit. If we’re publishing a book online, for instance, it might make sense to cache all of the chapters, images, etc. for offline viewing. There’s a fixed amount of content and—assuming there aren’t a ton of heavy images and videos—users will benefit from not having to download each chapter separately. On a news site, however, caching every article and photo will quickly fill up our users’ hard drives. If a site offers an indeterminate number of pages and assets, it’s critical to have a caching strategy that puts hard limits on how many resources we’re caching to disk. One way to do this is to create several different blocks associated with caching different forms of content. The more ephemeral content caches can have strict limits around how many items can be stored. Sure, we’ll still be bound to the storage limits of the device, but do we really want our website to take up 2 GB of someone’s hard drive? Here’s an example, again from my own site: const sw_caches = { static: { name: `${version}static` }, images: { name: `${version}images`, limit: 75 }, pages: { name: `${version}pages`, limit: 5 }, other: { name: `${version}other`, limit: 50 } } Here I’ve defined several caches, each with a name used for addressing it in the Cache API and a version prefix. The version is defined elsewhere in the Service Worker, and allows me to purge all caches at once if necessary. With the exception of the static cache, which is used for static assets, every cache has a limit to the number of items that may be stored. I only cache the most recent 5 pages someone has visited, for instance. Images are limited to the most recent 75, and so on. This is an approach that Jeremy Keith outlines in his fantastic book Going Offline (which you should really read if you haven’t already—here’s a sample). With these cache definitions in place, I can clean up my caches periodically and prune the oldest items. Here’s Jeremy’s recommended code for this approach: function trimCache(cacheName, maxItems) { // Open the cache caches.open(cacheName) .then( cache => { // Get the keys and count them cache.keys() .then(keys => { // Do we have more than we should? if (keys.length > maxItems) { // Delete the oldest item and run trim again cache.delete(keys[0]) .then( () => { trimCache(cacheName, maxItems) }); } }); }); } We can trigger this code to run whenever a new page loads. By running it in the Service Worker, it runs in a separate thread and won’t drag down the site’s responsiveness. We trigger it by posting a message (using postMessage()) to the Service Worker from the main JavaScript thread: // First check to see if you have an active service worker if ( navigator.serviceWorker.controller ) { // Then add an event listener window.addEventListener( "load", function(){ // Tell the service worker to clean up navigator.serviceWorker.controller.postMessage( "clean up" ); }); } The final step in wiring it all up is setting up the Service Worker to receive the message: addEventListener("message", messageEvent => { if (messageEvent.data == "clean up") { // loop though the caches for ( let key in sw_caches ) { // if the cache has a limit if ( sw_caches[key].limit !== undefined ) { // trim it to that limit trimCache( sw_caches[key].name, sw_caches[key].limit ); } } } }); Here, the Service Worker listens for inbound messages and responds to the “clean up” request by running trimCache() on each of the cache buckets with a defined limit. This approach is by no means elegant, but it works. It would be far better to make decisions about purging cached responses based on how frequently each item is accessed and/or how much room it takes up on disk. (Removing cached items based purely on when they were cached isn’t nearly as useful.) Sadly, we don’t have that level of detail when it comes to inspecting the caches…yet. I’m actually working to address this limitation in the Cache API right now. Your users always come first The technologies underlying Progressive Web Apps are continuing to mature, but even if you aren’t interested in turning your site into a PWA, there’s so much you can do today to improve your users’ experiences when it comes to media. And, as with every other form of inclusive design, it starts with centering on your users who are most at risk of having an awful experience. Draw distinctions between critical, nice-to-have, and superfluous media. Remove the cruft, then optimize the bejeezus out of each remaining asset. Serve your media in multiple formats and sizes, prioritizing the smallest versions first to make the most of high latency and slow connections. If your users say they want to save data, respect that and have a fallback plan in place. Cache wisely and with the utmost respect for your users’ disk space. And, finally, audit your caching strategies regularly—especially when it comes to large media files.Follow these guidelines, and every one of your users—from folks rocking a JioPhone on a rural mobile network in India to people on a high-end gaming laptop wired to a 10 Gbps fiber line in Silicon Valley—will thank you. Full Article
ue Conformation-dependent design of sequences in copolymers [electronic resource] / volume editor, Alexei R. Khokhlov ; with contribution by V.O. Aseyev [and others] By darius.uleth.ca Published On :: New York : Springer, [2006] Full Article
ue Navy ship with 698 evacuees departs from Male for Kochi By www.thehindu.com Published On :: Sat, 09 May 2020 01:30:35 +0530 Indian envoy lauds Maldives govt. for its ‘wonderful support and helping hand’ in evacuation Full Article National
ue The Hemingway Society reprints “Love in the Time of Influenza: Hemingway and the 1918 Pandemic” By www.kentstateuniversitypress.com Published On :: Tue, 21 Apr 2020 17:44:58 +0000 The Hemingway Society reprints “Love in the Time of Influenza: Hemingway and the 1918 Pandemic” by Susan F. Beegel. “In 1918 a virulent strain of influenza emerged that would spread around the world, fueled by World War I with its patriotic rallies and parades, its streams of refugees, and its mass movements of troops, such as the [...] Full Article News hemingway History pandemic world war I
ue Animals that Fueled the World By endeavors.unc.edu Published On :: Wed, 15 Apr 2020 11:30:31 +0000 When an archaeologist uncovers an artifact, while likely enthralled by the piece, they are more interested in what it can teach them about human behavior. Zooarchaeologists have a similar goal. UNC researchers Benjamin Arbuckle and Heather Lapham use ancient animal remains, texts, and iconography to understand how relationships with animals changed peoples’ lives and the world. Full Article Society ancient animal Archaeology artifact bones excavation field work remains zooarchaeology