缺前端是假的,缺優秀前端是真的
現在,幾乎整個網際網路行業都缺前端工程師,不僅在剛起步的創業公司,在上市公司乃至巨頭,這個問題也一樣存在。沒錯,優秀的前端工程師簡直比大熊貓還稀少。
在國外,前端工程師一樣是需求旺盛、供不應求的香餑餑。舉個例子,根據indeed.com抓取的數千家網站的職位顯示:目前前端的熱門崗位——「HTML5」是需求增長最快的開發崗位,在所有開發職位中排名第一,MongoDB和iOS緊隨其後位列第二、第三。
道理都懂,可是為什麼還是沒有找到滿意的工作?
其實前端一點也不簡單
很多人認為前端開發是一個「相對於其他模組來說更簡單的領域」,比如:
1、把Photoshop檔案、圖片或者線框放進一個網頁;
2、偶爾設計Photoshop檔案、圖片或者線框;
3、用JS程式設計,為網頁製作動畫、過渡效果;
4、用HTML和CSS程式設計,確定網頁的內容和形式。
事實上,前端工程師是這樣的:
1、在設計師和工程師之間建立視覺化的語言;
2、用視覺化的設計,定義一組代表內容、品牌和功能的元件;
3、為Web應用程式的公約、框架、需求、視覺化的語言和規格設定底線;
4、定義Web應用程式的裝置、瀏覽器、螢幕、動畫的範圍;
5、開發一個質量保證指南來確保品牌忠誠度、程式碼質量、產品標準;
6、為Web應用程式設定適當的行距、字型、標題、圖示、餘糧、填充等等;
7、為Web應用程式設定多種解析度的影像,裝置為主的實體模型,同時維護設計指南;
8、用account semantics, accessibility, SEO, schemas ,microformats 標記Web應用程式;
9、用一種友好的,消耗小的,裝置和客戶端感知的方式連線API,獲取內容;
10、開發客戶端程式碼來顯示流暢的動畫、過渡、延遲載入、互動、應用工作流程,大多數時間用來考慮漸進增強和向後相容的標準;
11、保證後臺連線安全,採取跨地資源共享( CORS )的程式考慮,防止跨站點指令碼( XSS)和跨站點請求偽造( CSRF ) ;
12、最重要的是,儘管有嚴格的期限、利益相關者的要求,以及裝置的限制,無論現在還是將來永遠是「客戶第一」。
為了實現上述目標,前端工程師採用了從視覺化到程式設計的多種工具 ,甚至有時要照顧市場、 UX 到內容tweakes等等。
和優秀前端的差距這麼大?
由於前端工程師的入門門檻非常低,JS、CSS、HTML並不是很難入門掌握的語言,似乎只要花一點時間,就可以通過網上教程和書本學會它,然而我發現事情並不簡單。
自己是從事五年的前端工程師了,不少人私下問我,2019年前端該怎麼學啊,方法有沒有?
沒錯,年初我花了一個多月的時間整理出來的學習資料,希望能幫助那些想學習前端,卻又不知道怎麼開始學習的童鞋。
給大家推薦下我們的web前端學習群:731,771,211. 從最基礎的HTML+CSS+JS【炫酷特效,遊戲,外掛封裝,設計模式】到移動端HTML5的專案實戰的學習資料都有整理,送給每一位前端小夥伴。2019最新技術,與企業需求同步。好友都在裡面學習交流,每天都會有大牛定時講解前端技術
自學是這樣做的:
1、濫用JS庫,因為實際上並不了JS的內部(e.g. 一切都用jQuery);
2、濫用JS外掛,抄別人的程式碼哪怕自己根本讀不懂(e.g.jQuery.doParallaxPls.js);
3、給Web應用程式新增CSS框架,卻只用到CSS/JS的5%,沒有看到任何的需求、設計或者比較和評價;
4、認為只要新增了CSS框架,網站就可以「有求必應」;
5、一邊在說著「響應式web設計」,卻對伺服器端技術一無所知;
6、用CSS程式設計時不管前處理器、命名規範等,卻用不合適的selector/ids/magic numbers等;
7、忽視表現、記憶體洩露(並不理解記憶體洩露的真正含義),不會檢測程式碼;
8、不會用指標衡量一個產品,或者這種指標旨在自己的電腦、瀏覽器、裝置有效;
9、忽視軟體技術。
入門容易精通難,計算機和軟體的基礎對JS的使用或瀏覽器程式設計都非常重要。web可能是最有影響力的平臺和環境之一,在那裡執行的程式必須被小心對待。一位優秀的前端工程師不僅要考慮web技術和語言,並且還要了解所有不同的元件、系統和概念。
優秀的前端工程師是這樣做的****(這才是市場急需的前端):
1、DNS解析、使用CDN和關於multiple Hostnames as part of resources request.
2、HTTP Headers (Expires, Cache-Control, If-Modified-Since)
3、Steve Souders的所有規則(High Performance Websites)
4、如何解決PageSpeed, YSlow, Chrome Dev Tools Audit, Chrome Dev Tools Timeline顯示的所有問題;
5、何時把任務傳到伺服器和客戶端;
6、快取,預取和負荷技術的使用;
7、Native JS,知道何時從頭開始做,何時查詢別人的程式碼,同時可以評估這樣做的優缺點;
8、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、CSS標準、modern conventions、 strategies (e.g. BEM, SMACSS, OOCSS)的知識和用法;
10、JS的電腦知識(記憶體管理,單執行緒的性質,垃圾收集演算法,超時,範圍,提升,模式)
換句話說,如果說精通HTML+CSS+JS,瞭解後端知識,只是60分的合格前端;那麼要想成為受追捧、拿高薪的80分優秀前端,要對業務需求和、架構設計有真正的運用;而100分的頂級前端,則必須要能夠兼顧技術和設計,更接近「以前端開發為主的全棧工程師」了。
缺前端是假的,缺優秀前端是真的
現在,前端工程師終於前所未有的在web中佔有了一席之地。隨著多裝置、瀏覽器和Web標準的演變革命,前端正在成為兼顧邏輯、效能、互動、體驗的綜合性崗位,前端程式設計也變得越來越有挑戰和意義。
你還要浪費時間在迷茫又枯燥的自學當中嗎?
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901074/viewspace-2645524/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 我缺的是十連嗎?我缺的是歐氣!——論如何假裝培養玩家的歐氣
- DRBD是什麼意思?優缺點是什麼?
- 【缺缺缺人】杭州阿里飛豬招前端端端阿里前端
- 前端面試查漏補缺--(八) 前端加密前端面試加密
- 什麼是閉包,閉包的優缺點?
- 雲主機的優缺點是什麼呢
- 前端面試查漏補缺--(十) 前端鑑權前端面試
- 機櫃的種類和優缺點是什麼
- 臺灣伺服器的優缺點是什麼?伺服器
- 怎麼做優秀前端工程師 Web前端學習路線是什麼前端工程師Web
- 前端面試查漏補缺--(四) 前端本地儲存前端面試
- (1)微服務是什麼?它的優缺點有哪些?微服務
- 公鏈開發特點優缺點分析及前端實現前端
- Redis持久化RDB和AOF優缺點是什麼?Redis持久化
- 什麼是閉包?有哪些使用場景?優缺點是什麼?
- Jtti:mysql主從同步的優點和缺點是什麼JttiMySql主從同步
- Linux中LVM的工作原理是什麼?優缺點有哪些?LinuxLVM
- Docker的優缺點Docker
- 一份優秀的前端開發工程師簡歷是怎樣的?前端工程師
- Python垃圾回收機制是什麼?有哪些優缺點?Python
- 什麼是CN2線路?有哪些優缺點?
- 前端面試查漏補缺--(十五) Event Loop前端面試OOP
- Hive 優缺點Hive
- MapReduce優缺點
- RabbitMQ優缺點MQ
- HT UI 5.0,前端元件圖撲是認真的UI前端元件
- 內聯的優缺點
- 繼承的優缺點繼承
- MySQL索引的優缺點MySql索引
- 開源堡壘機是什麼?開源堡壘機的優缺點是什麼?
- 混合IT是什麼?基礎設施和優缺點有哪些?
- Linux中lvm分割槽是什麼?LVM優缺點有哪些?LinuxLVM
- 前端面試查漏補缺--(九) HTTP與HTTPS前端面試HTTP
- 你有使用過ExtJs嗎?說說它的優缺點是什麼?JS
- 什麼是實時渲染,3D實時渲染的優缺點3D
- 恆訊科技分析:共享主機的優點和缺點是什麼?
- Android:四大架構的優缺點,你真的瞭解嗎?Android架構
- 為什麼說js是弱型別語言,它的優缺點分別是什麼?JS型別