Notice
Recent Posts
Recent Comments
ยซ   2025/01   ยป
์ผ ์›” ํ™” ์ˆ˜ ๋ชฉ ๊ธˆ ํ† 
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
Today
In Total
๊ด€๋ฆฌ ๋ฉ”๋‰ด

A Joyful AI Research Journey๐ŸŒณ๐Ÿ˜Š

์นผ๋Ÿผ) “ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†๋Š” ์ด์œ ”๋ผ๋Š” ์นผ๋Ÿผ ์ฝ์€ ํ›„ ๋ณธ๋ฌธ

๐ŸŒณJob Search Resourcesโœจ/Book Reviews

์นผ๋Ÿผ) “ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†๋Š” ์ด์œ ”๋ผ๋Š” ์นผ๋Ÿผ ์ฝ์€ ํ›„

yjyuwisely 2023. 2. 4. 14:38


You can also think of front end as the “client side” of an application. So let's say you're a front end developer. This means your job is to code and bring to life the visual elements of a website. You'd be more focused on what the user sees when they visit a website or app.
์ฐธ๊ณ : https://kenzie.snhu.edu/blog/front-end-vs-back-end-whats-the-difference/


   ํ”„๋ก ํŠธ์—”๋“œ๋ผ๋Š” ๊ฑด ์›น์‚ฌ์ดํŠธ๋‚˜ ์•ฑ์„ ์ด์šฉํ•˜๋Š” ์œ ์ €๋“ค์˜ ์ธก๋ฉด์—์„œ ๋ณด๋Š” ๊ฑธ ๋งํ•œ๋‹ค. ์šฐ์—ฐํžˆ “ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†๋Š” ์ด์œ ”๋ผ๋Š” ์•„๋ž˜ ๋งํฌ์˜ ์นผ๋Ÿผ์„ ์ฝ๊ฒŒ ๋๊ณ  ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์•Œ์•„์•ผ ํ•˜๋Š” ๋ฆฌ์ŠคํŠธ ๋“ฑ์„ ์•Œ๋ ค์ค˜์„œ ์ •๋ง ์œ ์šฉํ•œ ๊ฒƒ ๊ฐ™๋‹ค.

Why can‘t we find Front End Developers (2014)

https://github.com/0xjjpa/whycantwefindfed
(ํ•œ๊ตญ์–ด ๋ฒˆ์—ญ๋ณธ์€ ์—ฌ๊ธฐ์„œ ๊ฐ€๋Šฅํ•˜๋‹ค. https://taegon.kim/archives/4810)

   ์›น ๊ฐœ๋ฐœ์ž ๊ณผ์ • ์ˆ˜์—…์„ ์ง€๊ธˆ๊นŒ์ง€ ํ•œ ๋‹ฌ ๋ฐฐ์šฐ๋ฉด์„œ HTML, CSS, Javascript๋ฅผ ๋ฐฐ์› ๊ณ  ํ˜„์žฌ ๊ฐœ์ธ ํฌํŠธํด๋ฆฌ์˜ค ์›น์‚ฌ์ดํŠธ๋ฅผ ๋งŒ๋“ค๊ณ  ์žˆ๋‹ค. ๋‚ด๊ฐ€ ์ƒ๊ฐํ•˜๋Š” ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ด๋ผ๋Š” ๊ฑด ๋”ฑ "1. ๋Œ€๋ถ€๋ถ„์˜ ์‚ฌ๋žŒ๋“ค์ด ์ƒ๊ฐํ•˜๋Š” ํ”„๋ก ํŠธ ์—”๋“œ๋ž€"์˜ 4๊ฐœ ๋ฆฌ์ŠคํŠธ์˜€๋Š”๋ฐ ํ˜„์‹ค์€ ์•„๋‹ˆ์—ˆ๋‹ค.๐Ÿคฃ ์ƒ๊ฐ๋ณด๋‹ค ์‹ ๊ฒฝ ์“ธ ๊ฒŒ ์ •๋ง ๋งŽ๋‹ค. 
   ํŠนํžˆ "2. ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์‹ค์ œ๋กœ ํ•˜๋Š” ๊ฒƒ"์˜ 6๋ฒˆ์—์„œ ๋‚˜์˜จ ๋‚˜์˜จ ๋งˆ์ง„, ํŒจ๋”ฉ ์ง€์ •ํ•˜๋ฉด์„œ ์ตœ๋Œ€ํ•œ ๊น”๋”ํ•˜๊ฒŒ ๋ณด์ด๋„๋ก ๋งŒ๋“œ๋Š” ๋ฐ ์‹œ๊ฐ„์ด ์–ด๋งˆ์–ด๋งˆํ•˜๊ฒŒ ๊ฑธ๋ ธ๋‹ค. ๊ธฐํš์ž, ์›น๋””์ž์ด๋„ˆ, UX/UI ๋””์ž์ด๋„ˆ, ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž, ๋ฐฑ์—”๋“œ ๊ฐœ๋ฐœ์ž ๋“ฑ ์ง์—…๋“ค์ด ์™œ ์„ธ๋ถ€์ ์œผ๋กœ ๋‚˜๋‰˜์–ด์žˆ๋Š”์ง€ ์•Œ ๊ฒƒ ๊ฐ™๋‹ค.

6. Style the Web Application with proper spacings, typography, headings, face fonts, icons, margins, paddings, grids and so on.
(Web applications include online forms, shopping carts, word processors, spreadsheets, video and photo editing, file conversion, file scanning, and email programs such as Gmail, Yahoo and AOL. Popular applications include Google Apps and Microsoft 365.)


ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์•Œ์•„์•ผ ํ•˜๋Š” ํˆด ๋“ฑ ๋ฆฌ์ŠคํŠธ๐Ÿ˜Š

- Visual Design tools (Photoshop, Adobe, Macaw, Sketch)
- Programming Tools (IDE's, Command Line, Source Version Control, Bash scripts, Build tasks)
- Marketing (Newsletters, Campaigns, Analytics, SEO, Social Media)
- UX (animations, transitions, feedback, interfaces, visual language
- Content tweakes (breakpoints, avoiding orphan words, readability, colors)
(SEO means Search Engine Optimization and is the process used to optimize a website's technical configuration, content relevance and link popularity so its pages can become easily findable, more relevant and popular towards user search queries, and as a consequence, search engines rank them better.)


   ๋‹จ์ˆœํ•˜๊ฒŒ ์ฝ”๋”ฉ๋งŒ ํ•  ์ค„ ์•„๋Š” ๊ฒŒ ์•„๋‹ˆ๊ณ  ์›น์˜ ์ž‘๋™ ์›๋ฆฌ, ์‚ฌ์šฉํ•˜๋Š” ์–ธ์–ด, ๋‹ค๋ฅธ ๋ชจ๋“  ๊ตฌ์„ฑ ์š”์†Œ, ์‹œ์Šคํ…œ, ์–ด๋–ป๊ฒŒ ์ƒํ˜ธ์ž‘์šฉํ•˜๋Š”์ง€ ๋“ฑ์„ ์•Œ์•„์•ผ ํ•˜๋‹ˆ๊นŒ ์ปดํ“จํ„ฐ ๊ณตํ•™์— ๋Œ€ํ•œ ์ง€์‹๋„ ํ•„์ˆ˜์ธ ๊ฒƒ ๊ฐ™๋‹ค. 

The fundamental mechanics of Computing and Software should always be taking into account even if you are coding in Javascript or in a browser. 

A good Front End Engineer will not only take in account the mechanics of the Web and the languages it uses, but also has experiences in all the different components, systems, and concepts than interact with it.

 

์ˆ™๋ จ๋œ ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์•Œ์•„์•ผ ํ•˜๋Š” ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ๋“ฑ ๋ฆฌ์ŠคํŠธ๐Ÿ˜Š

- Knowledge and usage of modern MVC Javascript libraries (e.g. AngularJS, EmberJS, ReactJS)
- graphic libraries (e.g. D3, SnapSVG)
- DOM manipulation libraries (e.g. jQuery, Zepto)
- lazy loading or package management libraries (e.g. RequireJS, CommonJS)
- task managers (e.g. Grunt, Gulp)
- package managers (e.g. Bower, Componentjs)
- testing (e.g. Protractor, Selenium)

 

   ์—ฌ๋Ÿฌ๋ชจ๋กœ ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ํ•ด์•ผ ํ•  ๊ฒƒ๊ณผ ์ง€์–‘ํ•ด์•ผ ํ•  ๊ฒƒ์„ ์•Œ๋ ค์ฃผ๋Š” ๋„์›€์ด ๋˜๋Š” ์นผ๋Ÿผ์ด๋‹ค. ๋˜ ๊ธฐ์–ตํ•ด์•ผ ํ•  ๊ฒƒ์€ ์‚ฌ์šฉ์ž๊ฐ€ ํ•ญ์ƒ ์ตœ์šฐ์„ ์ด๋ผ๋Š” ์ ์ด๋‹ค. 


1. ๋Œ€๋ถ€๋ถ„์˜ ์‚ฌ๋žŒ๋“ค์ด ์ƒ๊ฐํ•˜๋Š” ํ”„๋ก ํŠธ ์—”๋“œ๋ž€: 
1. What most people think Front Engineering is
:

  1. Taking a Photoshop file, Image, or Wireframe and making it into a webpage.
  2. Sometimes design previous Photoshop file, Image or Wireframe.
  3. Code Javascript, which creates animations and makes transitions inside a webpage.
  4. Code HTML and CSS, which defines content and styling inside a webpage.

2. ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์‹ค์ œ๋กœ ํ•˜๋Š” ๊ฒƒ:
2. What Front End Engineers actually do:

  1. Establish a visual language between Designers and Engineers
  2. From a Visual Design, define a set of components that represent content, brand, features, etc.
  3. Establish a baseline for the Web Application in terms of conventions, frameworks, requirements, visual languages and specs.
  4. Define the scope of the Web Application in terms of devices, browsers, screens, animations.
  5. Develop a Quality Assurance guideline to ensure brand fidelity, code quality, review of product by stakeholders.
  6. Style the Web Application with proper spacings, typography, headings, face fonts, icons, margins, paddings, grids and so on.
  7. Style the Web Application with multiple resolution images, device oriented mockups, all while taking care of design guidelines.
  8. Markup the Web Application taking into account semantics, accessibility, SEO, schemas and microformats.
  9. Connect to an API to retrieve information in a friendly, non-battery consuming, device and client aware way.
  10. Develop client side code to perform smooth animations, transitions, lazy loading, interactions, application workflows, most of the time taking into consideration progressive enhancement and backwards compatible standards.
  11. Ensure Backend connections are secure, taking Cross Origin Resource Sharing (CORS) procedures into account, protect against Cross Site Scripting (XSS) and Cross Site Request Forgery (CSRF).
  12. Never forgetting that despite strict deadlines, stakeholders requests, and device limitations, the User is, and will always be first.

In order to achieve aforementioned goals, Front End Engineers use many tools that range from
Visual Design tools (Photoshop, Adobe, Macaw, Sketch),
to Programming Tools (IDE's, Command Line, Source Version Control, Bash scripts, Build tasks).
Sometimes we even have to take care of Marketing (Newsletters, Campaigns, Analytics, SEO, Social Media),
UX (animations, transitions, feedback, interfaces, visual language)
to Content tweakes (breakpoints, avoiding orphan words, readability, colors).


3. ์•ˆ ์ข‹์€ ํ”„๋ก ํŠธ์—”๋“œ ์—”์ง€๋‹ˆ์–ด๋ง์ด๋ž€ (๊ทธ๋ž˜์„œ ์‹ค์ œ ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž์—๊ฒŒ ์•ˆ ์ข‹์€ ์˜ํ–ฅ์„ ์ฃผ๋Š” ๊ฒƒ):
3. What bad Front End Engineerings do (and thus hurting real Front End Engineers):

  1. Abuse of Javascript Libraries, since they don't really know the internals of Javascript (e.g. jQuery for everything).
  2. Abuse of Javascript Plugins, using other people's code without been able to even read it (e.g.  jQuery.doParallaxPls.js).
  3. Add to Web Application CSS Frameworks (Bootstrap, Foundation, Skeleton) while using 5% of the CSS/JS, without seeing any requirements, designs, or performing any kind of comparison/evaluation.
  4. Feed the idea that just because you add CSS Framework, a site is “Responsive”, or that responsiveness is some sort of spice you can just sprinkle into a Web Application at any time.
  5. Talking about “Responsive Web Design”, but being unaware of Server side techniques
  6. Coding CSS without conventions, preprocessors, naming standards, good practices, and at the same time writing CSS with over qualified selectors, ids, magic numbers, !important.
  7. Ignoring performance, memory leaks (not knowing what's a memory leak _really _is), failing to audit their code or measure it.
  8. Presenting a product without any kind of metrics, or the metrics being “It works on my Computer/Browser/Device”™
  9. Pretty much creating Software while Ignoring 30 years of Software Engineering.


Most of the time you want a **Computer Science **guy or girl that **then decided to work with Front End Engineering. **It's not a requirement to have a CS background to be a good Front End Engineer, **but
the fundamental mechanics of Computing and Software should always be taking into account even if you are coding in Javascript or in a browser. **Good Front End Engineers know that the web is probably one of the most powerful platforms and environments that exists, and as such, the code that is executed there, must be developed with the same care (or even more) than any other language in any other virtual machine or runtime.

A good Front End Engineer will not only take in account the mechanics of the Web and the languages it uses, but also has experiences in all the different components, systems, and concepts than interact with it. Here's a few things that an experienced Front End Engineer should know or do on top of just the normal Front End Engineering tasks:


4. ์ˆ™๋ จ๋œ ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๊ฐ€ ์•Œ์•„์•ผ ํ•˜๋Š” ๊ฒƒ๊ณผ ์ผ๋ฐ˜์ ์ธ ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž๋ณด๋‹ค ๋” ์•Œ์•„์•ผ ํ•˜๋Š” ๊ฒƒ (ํžŒํŠธ: ๋‹น์‹ ์ด ๊ณ ์šฉํ•˜๊ณ  ์‹ถ์€ ์ด๋“ค์„ ๋งํ•œ๋‹ค.) 
4. What experienced Front End Engineers need to know and do on top of good Front End Engineers **** (hint: this are the ones you want to hire):

  1. DNS Resolution, usage of Content Delivery Networks (CDN), and performance on multiple Hostnames as part of resources requests.
  2. HTTP Headers (Expires, Cache-Control, If-Modified-Since)
  3. All rules from Steve Souders (High Performance Websites)
  4. How to solve all problems showed by PageSpeed, YSlow, Chrome Dev Tools Audit, Chrome Dev Tools Timeline.
  5. When to leverage tasks to the server and when to the client.
  6. Usage of cache, pre-fetching and post-load techniques
  7. Native Javascript, knowing when to do something from scratch and when to look up for someone else code, and at the same time being able to evaluate the pros and cons of doing so.
  8. Knowledge and usage of modern MVC Javascript libraries (e.g. AngularJS, EmberJS, ReactJS), graphic libraries (e.g. D3, SnapSVG), DOM manipulation libraries (e.g. jQuery, Zepto), lazy loading or package management libraries (e.g. RequireJS, CommonJS), task managers (e.g. Grunt, Gulp), package managers (e.g. Bower, Componentjs) and testing (e.g. Protractor, Selenium).
  9. Image Formats, benefits, when to use which one and how, Image Optimisation techniques, and loading strategies (sprites, lazy loading techniques, cache flushing, PNG interlaced)
  10. Knowledge and usage of CSS Standards, modern conventions and strategies (e.g. BEM, SMACSS, OOCSS)
  11. The Computer Science of Javascript (memory management, single threaded nature, garbage collector algorithms, timeouts, scoping, hoisting, patterns)

728x90
๋ฐ˜์‘ํ˜•
Comments