Fixing Input Focus Issues
Ví dụ Radix’s tooltip bao quanh 1 dropdown → sau khi chọn dropdown hoặc nhấn ra ngoài để close dropdown content → cái buttun tự động bị focus lại và hiện tooltip!
1<DropdownMenuContent
2 align="end"
3 onCloseAutoFocus={(event) => event.preventDefault()}
4>
5 {/* Dropdown menu items */}
6</DropdownMenuContent>
We don’t need to modify the DOM to create highlight of the selected texts
Colors
1// Alpha
2$main-color: #806eea;
3// With alpha 33%
4.style {
5 color: rgba($main-color, 0.33);
6}
7// Or
8$color: rgba(20,20,20, .5);
BEM syntax
- "BEM" = Block, Element, Modifier.
- Goal: better understand the relationship between the HTML and CSS.
- Smart: everything is a class and nothing is nested.
👉 Read more: BEM 101 | CSS-Trick
1/* Block component */
2.btn {}
3
4/* Element that depends upon the block */
5.btn__price {}
6
7/* Modifier that changes the style of the block */
8.btn--orange {}
9.btn--big {}
SCSS / SASS
Heading numbering
Using FontAwesome in CSS
👉 Official doc.
1.login::before {
2 content: "\\f007";
3 font-family: "Font Awesome 5 Free";
4 font-weight: 900;
5}
px
vs em
vs rem
vs %
px
: not responsive.
em
: flexible + scalable + translated topx
.- Relative to element on which it's used.
1em = 16px
(default font-size Google Chrome)- Used for: headings, paragraphs, texts, elements related to typography (padding, margin).
rem
: flexible + scalable + translated topx
.- Relative to root HTML's font size.
- Change root font size -> change the hold project.
%
: relative to another component.- Used for height, width properties.
Image responsive and lazyload
1<img
2 srcset="elva-fairy-480w.jpg 480w, elva-fairy-800w.jpg 800w"
3 sizes="(max-width: 600px) 480px,
4 800px"
5 src="elva-fairy-800w.jpg"
6 alt="Elva dressed as a fairy" />
srcset
: allow browser to choose which file to load, based onsizes
sizes
: (in above example)- Media condition
(max-width: 600px) 480px
: screen ≤ 600px: The width of the slot
the image will fill when the media condition is true (480px) → choose the image which has the same size or 1st image that is bigger than the chosen slot! →elva-fairy-400w.jpg
- Other sizes of screen: slot size will be 800px → choose 1st image width ≥ 800px →
elva-fairy-800w.jpg
Create and combine svg icons
Combine 2 icons into one and generate a svg file. Eg. Combine "data" icon and "robot" icon into "data bot" icon.
- Find svg icons using these pages: icomoon, flaticon,... Down as
.svg
format. You should choose icons with single color.
- Using mediamodifier.com to combine them. Then download as
.jpg
files. Yep, with free account, you can only download this type of file.
- Using remove.bg to remove background and then save a new file in
.png
format.
- Using pngtosvg.com to convert to
.svg
file. Don't forget to reduce the number of color to 1 before clicking "Generate".
- Finally, download you desired svg icon.
Get rid of extra space:
svg
in div
1<div>
2 <svg style="display: block;" height="100" width="100"></svg>
3</div>
Inline-block elements (like
svg
, img
) sit on the text baseline. The extra space is for character descenders (eg. the tail of "y", "g",...) => We can use verticle-align: top
if we wanna keep it inline
or inline-block
.Terms
- Font ligatures: When you type
= + >
, it becomes⇒
.
Verticle align fontawesome icon and text
👇 Source.
1<div>
2 <i id="icon" class="far fa-copy"></i>
3 <span id="text">Text</span>
4</div>
1div {
2 display: inline-block;
3 height: 1rem;
4}
5#text, #ico {
6 line-height: 1rem;
7}
8#ico {
9 vertical-align: middle;
10}
Auto focus on an input field when page loads
Just add
autofocus
into the <input>
tag.1<input name="q" class="search" type="search" placeholder="..." autofocus>
Separate a list into 2 columns
And make it into 1 if the screen is small.
1<div class="two-columns-list">
2 <ul>
3 <li></li>
4 </ul>
5</div>
1.two-columns-list {
2 @media (min-width: $grid-md) {
3 @include column-count(2);
4 & > li {
5 padding-right: 10px;
6 }
7 }
8}
@media
not workingWhen I use bootstrap, the
@media
is not working when I change to mobile use, try to add below line to <head>
1<meta name="viewport" content="width=device-width" />