Front-end Development
Maya Shavin
Ruby Israel Meetup 2022
data:image/s3,"s3://crabby-images/2246c/2246c0287b003e5fa9c46924523e0f3a5311fba1" alt=""
data:image/s3,"s3://crabby-images/5d0c7/5d0c707d450ab6e0d9486bdb06c1740d04cf55bc" alt=""
Full-stack ?
Overflow
Front-end is not just about the front
Though it is about how to make it pretty...
Software development
BACK-END
Sit in the back and play with APIs, Database, performance, etc.
😉
FRONT-END
- Resolutions / Responsiveness
- Accessibility
- Performance (Yes, we have performance)
- SEO
- CSS layout (pixel-perfect alert)
- Is it beautiful enough?
- Frontend frameworks!!!
And more...
Responsiveness
- It should look good in 90% of the cases
- Learn CSS
- Use real devices (or Emulator) for testing
data:image/s3,"s3://crabby-images/b3c60/b3c60ed95df7a90ee9f55b09119b8efd428b5ed7" alt=""
data:image/s3,"s3://crabby-images/9b0a1/9b0a1d55a580db2fbbb62d43d6f884924ba87586" alt=""
data:image/s3,"s3://crabby-images/18bd0/18bd03a79b789806b6af204d2182869148f7140d" alt=""
data:image/s3,"s3://crabby-images/8adf3/8adf3c8412c1228940760b117e84b9f189cb95da" alt=""
-
Screen Reader Support
-
WAR ARIA compliance
-
Navigation (without mouse)
-
Media (colors, contrast)
Accessibility (A11Y)
data:image/s3,"s3://crabby-images/e4048/e4048f311ba1a08e9ef33e2e17c0a7d0466ceee6" alt=""
Web Content Accessibility Guidelines (WCAG)
Use of color
Background images
data:image/s3,"s3://crabby-images/3b62d/3b62d329e51a60fe93084a27d12748c6374ef911" alt=""
Visual alternative
Accessibility Compliance TEST
-
HTML semantic mark-up for elements
-
Media's alternative text
-
Keyboard compatibility
-
Visually-led content
-
Dynamic content
- Accessibility overlays
data:image/s3,"s3://crabby-images/acdda/acdda9815edc7b38092df155e243061c394341ef" alt=""
data:image/s3,"s3://crabby-images/1f157/1f1573f9e557c4206e98a5f1f70890d7875e81a8" alt=""
✅
❌
data:image/s3,"s3://crabby-images/5bc83/5bc836d0f3884a6ea6a3aeff39b882426252493b" alt=""
data:image/s3,"s3://crabby-images/83302/83302b737fc7b545d739fc09c4782d2da3da421e" alt=""
data:image/s3,"s3://crabby-images/933d6/933d6ba7363c30dd2bf51c2a89cb1d7861cb7adc" alt=""
data:image/s3,"s3://crabby-images/b0692/b069212b529beeff6d295fa68d3642851eb5c903" alt=""
data:image/s3,"s3://crabby-images/76f75/76f75ea3a866e586ae10ae661a21e836daee128a" alt=""
data:image/s3,"s3://crabby-images/1e6c5/1e6c588e3a0c5fa821dc69d5ad74c513a52301be" alt=""
data:image/s3,"s3://crabby-images/e1cdc/e1cdcb088f94abd03c29fafa320a635f0730c69a" alt=""
Front-end Optimization
Reducing file sizes and minimizing the number of requests needed for a given page to load
data:image/s3,"s3://crabby-images/3ef62/3ef624fc9bf6a003c0ea98c91ff4147448880d56" alt=""
data:image/s3,"s3://crabby-images/ec1be/ec1bedb2e7a9ebfbb5a7f4f8d283893619e09823" alt=""
data:image/s3,"s3://crabby-images/82ac3/82ac36efb40060458b22e8674f115f10f7c74d9b" alt=""
data:image/s3,"s3://crabby-images/6895d/6895d97704e6fcebf6aaac45eb38beff4acdf07e" alt=""
Front-end FRAMEWORKS
- Easy-to-use?
- Ecosystem support?
- Community?
- Performance?
- Not the next cool thing (not yet)
data:image/s3,"s3://crabby-images/78f18/78f18e4228222b5addb294f7875828aa863ba2a2" alt=""
data:image/s3,"s3://crabby-images/ed5c4/ed5c4c79ed0974e1e984a0dc9ba37bcd5cccf83e" alt=""
CSS Flexbox
- Dynamically distribute spaces between items
- Flexible adjustment of layout in any size
- One-directional flow
CSS Grid
- Two-dimensional grid-based layout system
- Keep layout consistent between items, with ability to resize automatically
CSS Variables
- Reuse values (color, font, size) across the application
- Easy to override on specific element
- Native to browser
data:image/s3,"s3://crabby-images/40649/40649b89372777580ebd445d111d0e7deabd13a4" alt=""
CSS Logical properties
- Localization support (language direction)
- Control layout through logical, rather than physical, direction and dimension mappings.
data:image/s3,"s3://crabby-images/fb469/fb469f8fad458dffb3f9da8b42cc089c489b03cb" alt=""
data:image/s3,"s3://crabby-images/9b418/9b418f261b6a6f1de9b70d200ba0e7d3f44bf01c" alt=""
data:image/s3,"s3://crabby-images/91c44/91c44652b6c50d3b2f1533df14bff193b4c0c216" alt=""
This is the summary! 😉
data:image/s3,"s3://crabby-images/8d136/8d136e31b0198665f1e8855fbfecbade5d95cfe3" alt=""
A LITTLE BIT about me
Senior Software Engineer
MICROSOFT
Core Team
STOREFRONT-UI
Organizer
VUEJS ISRAEL
Blogger & Book Author
@mayashavin
mayashavin.com
data:image/s3,"s3://crabby-images/0d697/0d697fb310b3cb8b66eb50f7a3a76c16ab3ae058" alt=""
data:image/s3,"s3://crabby-images/bf6f1/bf6f13fb5fd8015fdf795a3f7cf12563552a701e" alt=""
data:image/s3,"s3://crabby-images/ea66f/ea66fda8a44c3e610184b534a82bd4a10de8f059" alt=""
Thank you
data:image/s3,"s3://crabby-images/8a490/8a49026d5f5677949dabbc90095a22ef5017239c" alt=""
@mayashavin
mayashavin.com
Being a frontend dev
By Maya Shavin
Being a frontend dev
- 165