Time-saving tool for lazy (but efficient) developers.
9th March 2023
Web Development
This blog was primarily written for DECO1400 students (Introduction To Web Design) as suggested by the lecturer. The guide was endorsed in the ed Discussion Board and has been viewed by more than 400 students.
data:image/s3,"s3://crabby-images/52e73/52e736f04d6756ee9ffe8c3f520c782ab31e1158" alt="Emmet Icon Picture"
data:image/s3,"s3://crabby-images/214e7/214e787065285aaa8f93fe2dfc5d5d68ea591435" alt="Blog Post screenshot"
Are you tired of wasting your precious time typing out long repetitive lines of HTML/CSS code? Or rather dread the feeling of carpal tunnel set in after hours of coding? Well, look no further, for Emmet is here to save the day (and your hands).
As requested by some peers, I will be making a quick guide on the basics of Emmet and how it can improve your workflow tremendously.
Let's get straight into it.
You might not already know it yet, but you might be already using emmet! In the first practical, you might remember a short hand of initialising a html template using !.
data:image/s3,"s3://crabby-images/de39b/de39b449df6a2807fadebb12c9f563fb8c83855a" alt="Blog one picture one"
Pressing Enter should generate the following text:
data:image/s3,"s3://crabby-images/c95d0/c95d09345ad600d747eac8ab510fa442e9cbdce2" alt="Blog one picture two"
To create element tags, simply write the tags without the brackets.
data:image/s3,"s3://crabby-images/6c738/6c7382cd60a7fef221c72493d79fa648d307a7c7" alt="Blog one picture three"
As seen, some common attributes for certain tags have been already initialised for you. Simply press the Tab key to edit them instantly after creating the emmet expression.
Classes and ids can be added with a "." or "#" respectively, after the element tags.
data:image/s3,"s3://crabby-images/c6859/c6859592247a42126ff35441d7a5f2730028e1fa" alt="Blog one picture four"
You can also mix and match classes and id together. For div containers, the tag name is not required.
data:image/s3,"s3://crabby-images/532ed/532ed1c9d0fbd653c8713169ba11b5e5ae756a62" alt="Blog one picture five"
Add multiple classes.
data:image/s3,"s3://crabby-images/90e44/90e44bd1513e6dad5c74fa096d15d56f088131e3" alt="Blog one picture six"
Add custom attributes with square brackets []:
data:image/s3,"s3://crabby-images/908f0/908f00b3273f40c559b081b551f083f314909999" alt="Blog one picture seven"
Reminder: After making the emmet expression and pressing Enter, press Tab to quickly edit the details and text content of the element tag.
Make nested elements with > (parent > child).
data:image/s3,"s3://crabby-images/a22a0/a22a08ee15e7a15f2946bf7203dd331901b00674" alt="Blog one picture eight"
Add neighbouring elements with +.
data:image/s3,"s3://crabby-images/dd740/dd740a3c19340da0a336398488711318c8b3c8b9" alt="Blog one picture nine"
Note: Neighbouring elements are not the same as nested elems. If confused, I recommend you to review Nell's lecture on html.
Create multiple copies with *.
data:image/s3,"s3://crabby-images/f85f9/f85f990198edd03a79bd9fa07004c7e7f3e47434" alt="Blog one picture ten"
The sky's the limit for creating expressions and this is where Emmet especially shines.
data:image/s3,"s3://crabby-images/6cd37/6cd37bc36db217420d901056080e436803547859" alt="Blog one picture eleven"
You can also add text content to these elements directly from the expressions using {}. For lists, you can use $ to number them correspondingly. So for our previous example:
data:image/s3,"s3://crabby-images/28127/28127ac2bc7fbbf836ee9a7045f89b1e154e9832" alt="Blog one picture twelve"
Whew. Imagine writing these out manually.
Personally, I code with emmet in short successive bursts rather than a long one-liner (like the one above), but I find it really useful for the layering and identifier-naming shenanigans in my code. It also prevents potential opening and closing bracket bugs in your HTML code.
If you're using a commonly recognised attribute, you can also use :.
data:image/s3,"s3://crabby-images/28127/28127ac2bc7fbbf836ee9a7045f89b1e154e9832" alt="Blog one picture thirteen"
So far, I've been only displaying the powers of Emmet in HTML but you can also use emmet expressions in CSS. But because this guide is getting too long, here's a quick example:
data:image/s3,"s3://crabby-images/f3535/f353528fa5d12d9fc064f9c78de025c8ad270ba3" alt="Blog one picture twelve"
I encourage you to get used to Emmet as it allows you to not worry as much of the HTML/CSS syntax, but rather the logic and implementation in the design of your website.
With Emmet, you'll be spitting out HTML and CSS faster than a caffeinated squirrel on a keyboard.
So far, I've covered what I do 80% of the time with emmet but this barely scratches the surface of what Emmet has to offer. But if you want to learn more:
These are the docs for, what I think, the most useful keyboard shortcuts with Emmet:
https://docs.emmet.io/actions/wrap-with-abbreviation/
https://docs.emmet.io/actions/remove-tag/
Here's a cheatsheet for you to reference back to: https://docs.emmet.io/actions/remove-tag/
Let me know if you want to learn more useful tips and tricks for HTML/CSS/Js in the future of this course. Any questions, let me know in the comments.
Thanks @Iuliia Drugova for allowing me to post this.