TIL (Today I Learned)
A blog about web development, HTML, CSS, JavaScript, and web accessibility.
TIL #49
You can style the file selector button of file upload elements.
<label for="upload">Select file</label><br>
<input type="file" id="upload">
[type="file"]::file-selector-button {
background-color: hotpink;
padding: 0.5rem 1rem;
border: 2px solid fuchsia;
margin-block-end: 1rem;
display: block;
border-radius: 3px;
}
[type="file"]::file-selector-button:hover {
background-color: aqua;
}
TIL #48
You can use the :scope pseudo class to select direct children of an element with `.querySelectorAll()`.
<ul>
<li>A</li>
<li>B</li>
<li>C</li>
</ul>
<p>D</p>
console.log(document.body.querySelectorAll('*'))
// NodeList(5) [ul, li, li, li, p]
console.log(document.body.querySelectorAll(':scope > *'))
// NodeList(2) [ul, p]
TIL #47
console.count() logs the number of times that this particular call to count() has been called.
const letters = "availabilities".split("");
letters.forEach(letter => {
if (letter === 'i') {
console.count(`Letter ${letter}`)
}
})
/* Output:
Letter i: 1
Letter i: 2
Letter i: 3
Letter i: 4
*/
TIL #46
You can link to multiple e-mail addresses
<!-- comma separated list without spaces and/or url encoded with %20 -->
<a href="mailto:manuel@matuzo.at,manuel@webclerks.at">
Contact me and me
</a>
<!-- or with ?to= parameter -->
<a href="mailto:manuel@matuzo.at?to=manuel@webclerks.at">
Contact me and me
</a>
TIL #45
You can use the spellcheck attribute to instruct browsers that, if possible, an element should or should not be checked for spelling errors.
<textarea spellcheck="false">
Tis is jusst a test.
</textarea>
<div contenteditable spellcheck="false">
Tis is jusst a test.
</div>
TIL #44
You can animate z-index.
div {
position: absolute;
top: 0;
left: 0;
transition: z-index 2.5s;
}
TIL #43
You can make a link in an iframe open in its parent window, if you set target="_parent".
<!-- Parent File-->
<iframe src="https://codepen.io/matuzo/debug/YzGVXGV" frameborder="0"></iframe>
<!-- Embedded file -->
<ul>
<li>
<a href="https://a11yproject.com">no target</a>
</li>
<li>
<a href="https://a11yproject.com" target="_blank">target="_blank"</a>
</li>
<li>
<a href="https://a11yproject.com" target="_parent">target="_parent"</a>
</li>
</ul>
TIL #42
Adding an i (or I) before the closing bracket in an attribute selector causes the value to be compared case-insensitively.
<button class="mybutton">Send</button> <!-- red border -->
<button class="myButton">Send</button> <!-- green border -->
[class*="button" i] { /* matches mybutton and myButton */
border: 10px solid green;
}
[class*="button"] { /* matches only mybutton */
border-color: red;
}
TIL #41
ol and ul accept the type attribute. You can use it to set a different numbering type in HTML.
<ol type="a">
<li>Element 1</li>
<li>Element 2</li>
<li>Element 3</li>
</ol>
<ol type="A">
<li>Element 1</li>
<li>Element 2</li>
<li>Element 3</li>
</ol>
<ol type="i">
<li>Element 1</li>
<li>Element 2</li>
<li>Element 3</li>
</ol>
<ol type="I">
<li>Element 1</li>
<li>Element 2</li>
<li>Element 3</li>
</ol>
<ul type="1">
<li>Element 1</li>
<li>Element 2</li>
<li>Element 3</li>
</ul>
TIL #40
The order in which transform functions in the transform shorthand property are defined matters.
data:image/s3,"s3://crabby-images/9a345/9a3453a6a193fdcaec5bf723d00e36ba45c7459e" alt="The order in which transform functions in the transform shorthand property are defined matters."
TIL #39
You can use the nomodule attribute to run JavaScript code only in browsers that don’t support JS modules.
data:image/s3,"s3://crabby-images/5000e/5000e3ed697ec3290a066c63ae648c6a96c91fbb" alt="You can use the nomodule attribute to run JavaScript code only in browsers that don’t support JS modules."
TIL #38
Using the background-origin property you can position background images relative to the inner border edge (default), outer border edge, or the content edge.
data:image/s3,"s3://crabby-images/43eaa/43eaa8ef7100d6698e884283934b717533d585ef" alt="Using the background-origin property you can position background images relative to the inner border edge (default), outer border edge, or the content edge."
TIL #37
You can add the option { once: true } to an event listener to automatically remove it when has been invoked
data:image/s3,"s3://crabby-images/c680e/c680ec860e191bbaff7248e615d4ba1b90d34c49" alt="You can add the option { once: true } to an event listener to automatically remove it when has been invoked"
TIL #36
The nullish coalescing operator (??) only returns its right-hand side operand when its left-hand side operand is null or undefined.
data:image/s3,"s3://crabby-images/c051a/c051ac33239ece046fddca02b149ee8518483836" alt="The nullish coalescing operator (??) only returns its right-hand side operand when its left-hand side operand is null or undefined."
TIL #35
Optional chaining allows you to chain methods or properties, and conditionally continue down the chain if the value is not null or undefined.
data:image/s3,"s3://crabby-images/c2d0d/c2d0d64796484d5fae9b7532d2bf339a65962a58" alt="Optional chaining allows you to chain methods or properties, and conditionally continue down the chain if the value is not null or undefined."
TIL #34
You can use the removeProperty method to remove a specific inline CSS property defined in the style attribute.
data:image/s3,"s3://crabby-images/e680c/e680c898fef335659ddcdcd4eda4afc711c9d6fa" alt="You can use the removeProperty method to remove a specific inline CSS property defined in the style attribute."
TIL #33
There’s a space-separated syntax for values in functional color notations.
data:image/s3,"s3://crabby-images/ceffc/ceffcaded59089a830c53ffb4427a0541b364c2e" alt="There’s a space-separated syntax for values in functional color notations."
TIL #32
JSON.stringify takes 3 parameters. The third parameter can be used to pretty-print the output.
data:image/s3,"s3://crabby-images/16b09/16b096bcbb943dea86555b0bb92d45aee9ecc492" alt="JSON.stringify takes 3 parameters. The third parameter can be used to pretty-print the output."
TIL #31
There's native, CSS-only smooth scrolling.
data:image/s3,"s3://crabby-images/82d70/82d70e06bf07bc92d9c16d8b7cb1864958e46d96" alt="There's native, CSS-only smooth scrolling."
TIL #30
You can target Inverted Colors Mode mode in CSS
data:image/s3,"s3://crabby-images/215ac/215ac96d692cd9c245907d57cceae4dd2077a4dc" alt="You can target Inverted Colors Mode mode in CSS"
TIL #29
You can use JavaScript (Vibration API) to vibrate devices
data:image/s3,"s3://crabby-images/be716/be7165d1e178cd28be05ab98aed1416073715f54" alt="You can use JavaScript (Vibration API) to vibrate devices"
TIL #28
You can disable all form elements in a fieldset by setting the disabled attribute on the fieldset.
data:image/s3,"s3://crabby-images/5baca/5baca04dd47f9c7143dd8d30ed9f7c44e31cb8cc" alt="You can disable all form elements in a fieldset by setting the disabled attribute on the fieldset."
TIL #27
You can list all pseudo elements of an element in the CSS pane in Firefox Developer Tools.
data:image/s3,"s3://crabby-images/9f68b/9f68bc7ffdb09f44cd89e666ed2d21a0d5fb288d" alt="You can list all pseudo elements of an element in the CSS pane in Firefox Developer Tools."
TIL #26
You can emulate dark mode and reduced motion in Chrome Dev Tools.
data:image/s3,"s3://crabby-images/f32b9/f32b950ac8ba03e805a80f119b47c35adfd08429" alt="You can emulate dark mode and reduced motion in Chrome Dev Tools."
TIL #25
You can instruct browsers to print pages in landscape orientation (Chrome/Opera only).
data:image/s3,"s3://crabby-images/36566/36566b8015af360ec1395a2fb2992e5f669ed9d6" alt="You can instruct browsers to print pages in landscape orientation (Chrome/Opera only)."
TIL #24
You can change the filename of a downloadable file by defining a value in the download attribute.
data:image/s3,"s3://crabby-images/8eccc/8eccc8efbcdc84be0aac8ca1a686a80ed9ddc22c" alt="You can change the filename of a downloadable file by defining a value in the download attribute."
TIL #23
The bullet or number of a list-item can be selected and styled with the ::marker pseudo-element.
data:image/s3,"s3://crabby-images/98b1d/98b1d24b407f38386ce0d9167eec6eebacb13eed" alt="The bullet or number of a list-item can be selected and styled with the ::marker pseudo-element."
TIL #22
If an input element has the attribute value autocomplete="new-password", browsers can suggest securely-generated passwords.
data:image/s3,"s3://crabby-images/c26ea/c26ea26fdc344ecacc063aa4a1bfe80e83f1b2ce" alt="If an input element has the attribute value autocomplete="
TIL #21
You can use the CSS Paint API to create background images in CSS.
data:image/s3,"s3://crabby-images/b7bab/b7babf37c06575a94fa7abe09fe1dd144b3b187e" alt="You can use the CSS Paint API to create background images in CSS."
TIL #20
You can search the elements panel in Developer Tools not only for strings but also selectors.
data:image/s3,"s3://crabby-images/685cd/685cdef83bd4b935e9686e6143a6f1fe949b75b4" alt="You can search the elements panel in Developer Tools not only for strings but also selectors."
TIL #19
The webkitdirectory attribute allows users to select directories instead of files. (desktop browsers only)
data:image/s3,"s3://crabby-images/08dc4/08dc4122293bee71461765fd04e210f1e4444f87" alt="The webkitdirectory attribute allows users to select directories instead of files. (desktop browsers only)"
TIL #18
It's possible to identify how many separate fingers are touching the screen.
data:image/s3,"s3://crabby-images/18279/182799edcbc9be96d88e47513571a62284500e3a" alt="It's possible to identify how many separate fingers are touching the screen."
TIL #17
You can do responsive preloading because preload link elements accept the media attribute like any other link element.
data:image/s3,"s3://crabby-images/dab3f/dab3fac08705c24d977c34d81b206e2ae31e5dca" alt="You can do responsive preloading because preload link elements accept the media attribute like any other link element."
TIL #16
SVGs are focusable in Internet Explorer. We can set focusable="false" to prevent that.
data:image/s3,"s3://crabby-images/d4e5e/d4e5ea6b93a512231a34a19e4a88f3f725dcb4bc" alt="SVGs are focusable in Internet Explorer. We can set focusable="
TIL #15
macOS uses Papyrus as the default font when you define the generic font family “fantasy”.
data:image/s3,"s3://crabby-images/c3ec1/c3ec14821805d49bf2518c2e81f9e40d10915ecc" alt="macOS uses Papyrus as the default font when you define the generic font family “fantasy”."
TIL #14
text-decoration doesn't have to be a solid line. There’s also dotted, dashed, double, and wavy.
data:image/s3,"s3://crabby-images/a0525/a0525640231ac0d2f636ec6fcf1fd5a6a776e857" alt="text-decoration doesn't have to be a solid line. There’s also dotted, dashed, double, and wavy."
TIL #13
text-decoration is a shorthand property for text-decoration-line, text-decoration-color, and text-decoration-style.
data:image/s3,"s3://crabby-images/1add7/1add7669292ad6e6c8b98701954b08300c24d45d" alt="text-decoration is a shorthand property for text-decoration-line, text-decoration-color, and text-decoration-style."
TIL #12
Overflowing block-level elements with overflow set to scroll or auto are focusable in Firefox.
data:image/s3,"s3://crabby-images/d1328/d1328a02906bedb0d30c5f809e935f6be039d298" alt="Overflowing block-level elements with overflow set to scroll or auto are focusable in Firefox."
TIL #11
You can use conditional comments to target specific versions of Outlook.
data:image/s3,"s3://crabby-images/1eacf/1eacf72b2728e854595c05be2ab82b17f05ace9b" alt="You can use conditional comments to target specific versions of Outlook."
TIL #10
You can turn the outline of an element to the _inside_ by setting the outline-offset property to a negative value. (Not supported in IE)
data:image/s3,"s3://crabby-images/803aa/803aa0810b635afdba18be062ee57f7abf277861" alt="You can turn the outline of an element to the _inside_ by setting the outline-offset property to a negative value. (Not supported in IE)"
TIL #9
You can center a flex-item vertically and horizontally by applying margin: auto; to it.
data:image/s3,"s3://crabby-images/dd69e/dd69e2e87322f526207e66c1527c7691f4915ae1" alt="You can center a flex-item vertically and horizontally by applying margin: auto; to it."
TIL #8
If you press CMD/Ctrl and click on a property or property value in the style panel, @ChromeDevTools jumps directly to the respective css/scss file and line.
data:image/s3,"s3://crabby-images/572e3/572e30eab5ea7ac7f59304caf1d156f4466278d5" alt="If you press CMD/Ctrl and click on a property or property value in the style panel, @ChromeDevTools jumps directly to the respective css/scss file and line."
TIL #7
About the @at-root directive. It moves nested styles out from within a parent selector or nested directive.
data:image/s3,"s3://crabby-images/25c94/25c9439a0187194937541432302ccf7321dde6bd" alt="About the @at-root directive. It moves nested styles out from within a parent selector or nested directive."
TIL #6
IE 11 requires a unit to be added to the third argument (flex-basis) of the flex property.
data:image/s3,"s3://crabby-images/7cfdb/7cfdbaea396aa450d0770957eb9fa8b400c1d975" alt="IE 11 requires a unit to be added to the third argument (flex-basis) of the flex property."
TIL #5
You can use `navigator.connection` to get information about the connection like round-trip time, bandwidth, connection type (e.g. 3g, 4g) or if Data-Saver is enabled.
data:image/s3,"s3://crabby-images/9aff3/9aff3707bb4b00a25f2db2c220da001b421a5410" alt="You can use `navigator.connection` to get information about the connection like round-trip time, bandwidth, connection type (e.g. 3g, 4g) or if Data-Saver is enabled."
TIL #4
The grid-auto-flow property takes up to two values. row, column, dense, row dense, or column dense.
data:image/s3,"s3://crabby-images/95a8d/95a8d9d6723b25ef224e13ca0c364540cbe654cc" alt="The grid-auto-flow property takes up to two values. row, column, dense, row dense, or column dense."
TIL #3
You can pass an `options` object, which only has a single property, to the `focus()` method to prevent scrolling on focus.
data:image/s3,"s3://crabby-images/f5098/f50985ff7e7eb92c34f234e357bfb5d9ef82a29e" alt="You can pass an `options` object, which only has a single property, to the `focus()` method to prevent scrolling on focus."
TIL #2
There’s a tab-size property. It controls the width of the tab (U+0009) character.
data:image/s3,"s3://crabby-images/96750/96750674fd0bb9851d9e2850a7fe785f83059c09" alt="There’s a tab-size property. It controls the width of the tab (U+0009) character."
TIL #1
How to get a random background-color (or any other value) each time I compile Sass.
data:image/s3,"s3://crabby-images/2f3c8/2f3c801d349e0430b6ef464c09a54f41463edff1" alt="How to get a random background-color (or any other value) each time I compile Sass."