.htm和.html差別:沒有本質的差別。.htm是在win32時代,系統隻能識别3位擴充名時使用的。現在一般都使用.html。
作為一名最基礎的前端工程師你必須掌握HTML、CSS和JavaScript。三者必須同時精通,類似我字樣對前端知識一知半解的,一遇到問題就停下工作就四處搜尋解決方案的,首先就算不上一個合格的前端人員。像我這樣的如果當了前端工程師那工期肯定是不能保證的。合格的前端工程師第一要學會的就是在沒有任何外來幫助的情況下(包括搜尋引擎),能夠完成大多數任務。
以下知識點是作為一個前端工程師必須了解和熟悉的:
- DOM結構——兩個節點之間可能存在哪些關系以及如何在節點之間任意移動。
- DOM操作——怎樣添加、移除、移動、複制、建立和查找節點。
- 事件——怎樣使用事件以及IE和DOM事件模型之間存在哪些主要差别。
- XMLHttpRequest——這是什麼、怎樣完整地執行一次GET請求、怎樣檢測錯誤。
- 嚴格模式與混雜模式——如何觸發這兩種模式,區分它們有何意義。
- 盒模型——外邊距、内邊距和邊框之間的關系,IE < 8中的盒模型有什麼不同。
- 塊級元素與行内元素——怎麼用CSS控制它們、它們怎樣影響周圍的元素以及你覺得應該如何定義它們的樣式。
- 浮動元素——怎麼使用它們、它們有什麼問題以及怎麼解決這些問題。
- HTML與XHTML——二者有什麼差別,你覺得應該使用哪一個并說出理由。
- JSON——它是什麼、為什麼應該使用它、到底該怎麼使用它,說出實作細節來。
上述這些知識點都應該是你“想都不用想”就知道的東西。除了上述的前端知識,也還需學會至少一門後端程式設計語言,讓你自己學會如何與後端進行更好的互動。
很多前端工程師對一些庫非常的熟悉,jQuery,Bootstrap等,但是對于庫的熟悉并不能提現你的優秀,整整優秀的是那些了解庫背後的機制,特别是能夠徒手寫出一個自己的庫的人。
真正合格的前端工程師是能實作具體的功能要求,而優秀的前端工程師需要解決的問題是尋找一個最優的解決方案。
二、溝通很重要
優秀的前端工程師需要具備良好的溝通能力,因為你的工作與很多人的工作息息相關。在任何情況下,前端工程師至少都要滿足下列四類客戶的需求。
- 産品經理——這些是負責策劃應用程式的一群人。他們能夠想象出怎樣通過應用程式來滿足使用者需求,以及怎樣通過他們設計的模式賺到錢(但願如此)。一般來說,這些人追求的是豐富的功能。
- UI設計師——這些人負責應用程式的視覺設計和互動模拟。他們關心的是使用者對什麼敏感、互動的一貫性以及整體的好用性。他們熱衷于流暢靓麗但并不容易實作的使用者界面。
- 項目經理——這些人負責實際地運作和維護應用程式。項目管理的主要關注點,無外乎正常運作時間——應用程式始終正常可用的時間、性能和截止日期。項目經理追求的目标往往是盡量保持事情的簡單化,以及不在更新更新時引入新問題。
- 最終使用者——當然是應用程式的主要消費者。盡管我們不會經常與最終使用者打交道,但他們的回報意見至關重要;沒人想用的應用程式毫無價值。最終使用者要求最多的就是對個人有用的功能,以及競争性産品所具備的功能。
不要在沒有作出評估之前就随便接受某項任務。你必須始終記住,一定先搞清楚别人到底想讓你幹什麼,不能簡單地接受“這個功能有問題”之類的大概其的說法。而且,你還要确切地知道這個功能或設計的真正意圖何在。“加一個按鈕”之類的任務并不總意味着你最後會加一個按鈕。還可能意味着你會找産品經理,問一問這個按鈕有什麼用處,然後再找UI設計師一塊探讨按鈕是不是最佳的互動手段。要成為優秀的前端工程師,這種溝通至關重要。
那麼,前端工程師應該最關注哪些人的意見呢?答案是所有這四類人。優秀的前端工程師必須知道如何平衡這四類人的需求和預期,然後在此基礎上拿出最佳解決方案。由于前端工程師處于與這四類人溝通的交彙點上,是以其溝通能力的重要性不言而喻。如果一個非常酷的新功能因為會影響前端性能,必須删繁就簡,你怎麼跟産品經了解釋?再比如,假設某個設計如果不改回原方案可能會給應用程式造成負面影響,你怎麼才能說服UI設計師?作為前端工程師,你必須了解每一類人的想法從何而來,必須能拿出所有各方都能接受的解決方案。從某種意義上說,優秀的前端工程師就像是一位大使,需要時刻抱着外交官的心态來應對每一天的工作。
專業技術可能會引領你進入成為前端工程師的大門,但隻有運用該技術創造的應用程式以及你跟他人并肩協同的能力,才會真正讓你變得優秀。
三、提升無止境
優秀的前端工程師應該具備快速學習能力。推動Web發展的技術并不是靜止不動的,這些技術幾乎每天都在變化,如果沒有快速學習能力,你就跟不上Web發展的步伐。你必須不斷提升自己,不斷學習新技術、新模式;僅僅依靠今天的知識無法适應未來。Web的明天與今天必将有天壤之别,而你的工作就是要搞清楚如何通過自己的Web應用程式來展現這種翻天覆地的變化。
- QCon/Velocity/SDCC
- JSConf/NodeConf
- YDN/YUIConf
- 計算機知識儲備
- 編譯原理
- 計算機網絡
- 作業系統
- 算法原理
- 軟體工程/軟體測試原理
- 軟技能
- 知識管理/總結分享
- 溝通技巧/團隊協作
- 需求管理/PM
- 互動設計/可用性/可通路性知識
- 可視化
- SVG/Canvas/VML
- 後端工程師
- 程式設計語言
- C/C++/Java/PHP/Ruby/Python/…
- 資料庫
- SQL
- MySQL/MongoDB/Oracle
- Unix/Linux/OS X/Windows
-
資料結構