初級Web前端工程師掌握這些知識點,月薪8000妥妥滴

来源:https://www.cnblogs.com/TT485480/archive/2020/05/18/12909749.html
-Advertisement-
Play Games

今天給大家整理出來了web前端工程師初級階段需要掌握的內容,很全面,希望大家好好閱讀,看看自己掌握的知識點和文章裡面寫的還相差多少。 什麼是初級web前端工程師? 初級前端工程師:首先要知道的就是如何處理各種瀏覽器的相容處理(比如說在IE瀏覽器中的createElement有什麼不同等等內容),現在 ...


今天給大家整理出來了web前端工程師初級階段需要掌握的內容,很全面,希望大家好好閱讀,看看自己掌握的知識點和文章裡面寫的還相差多少。

 

什麼是初級web前端工程師?

初級前端工程師:首先要知道的就是如何處理各種瀏覽器的相容處理(比如說在IE瀏覽器中的createElement有什麼不同等等內容),現在基本上每個公司在招聘的時候都會要求熟練html5, css3, javascript,這個熟練的意思就是信手拈來。

在下麵會說初級前端工程師應該具體的學習哪些知識,然後就是要瞭解各種css的預處理器和後處理器, 還有會使用常見前端的MV*框架(angularjs, backbone,reactjs等等)並知道這些框架的原理,另外就是要熟練使用nodejs,要會使用基於node的各種前端構建工具 (grunt,gulp等等),熟練使用github或gitlab,對模塊化、組件化、工程化、語義化有一個比較深入的瞭解,最後要知道如何開發移動端 的頁面,如何去優化一個頁面的性能。

初級web前端工程師的技術體系

1、HTML部分

首先是要掌握一些常用標簽的使用和他們的各個屬性,這些常用的標簽我總結了一下有以下這些:

  • html:頁面的根元素。
  • head:頁面的頭部標簽,是所有頭部元素的容器。
  • body:頁面的主體標簽,頁面展現的內容就放置在這裡面。
  • title:頁面的標題。
  • meta:位於文檔的頭部,提供頁面的元信息,包括關鍵字、描述等等。
  • link:定義文檔與外部資源的關係,最常用的用途就是引入樣式表。
  • script:腳本標簽,可以把js腳本代碼放置在這個標簽內,也可以使用這個標簽的src屬性引入一個外部標簽。
  • style:樣式標簽,可以把css代碼寫在這個標簽中。
  • a:超鏈接,href屬性代表要鏈接到的地方,target屬性代表打開方式。
  • img:圖像標簽,src屬性表示圖片的位置。
  • form:表單元素,它內部的input、select、textarea等標簽都是比較重要的。
  • div:定義文檔中的分區或節,可以使用div來進行頁面的佈局等操作。
  • 另外還有ul、li、p、button、iframe、p、table等標簽也很常用,nav、section、article、header、aside、footer等語義化標簽也需要瞭解一下。

除了要瞭解上面這一些標簽之外,還需要對一些新的HTML5的API有一定的瞭解:

  • audio、video標簽。
  • Canvas:定義圖形,比如圖表和其他圖像。
  • input標簽的accept屬性,email、phone、url等類型。
  • getElementByClassName根據class名來獲取一個元素結點。
  • Multiple file selection多文件選擇屬性。
  • html的import、template
  • process標簽,webGL等內容。

還有一些要知道的知識點:

1.doctype的作用。

2.unicode、utf8等編碼的原理和區別。

3.如何進行頁面性能優化。

4.png、jpg、webp、gif等圖片格式的不同的優勢。

5.HTML行內元素與塊級元素的區別。

6.移動web端開發常用head標簽。

7.web語義化。

8.瀏覽器中的緩存原理

2、CSS部分

關於css這一塊,我的看法就是網上下載一個chm格式的css的參考手冊,然後根據手冊裡面寫的一個個的都敲一下。

css大體分為下麵這幾塊知識點:

① 定位佈局

1.position屬性的7個值(static | relative | absolute | fixed | center | page | sticky)分別有什麼作用和不同?

2.實現品字形佈局或者是三欄佈局(左右寬度固定,中間適應屏幕)。

3.浮動與清除浮動的方法,flex佈局,grid佈局。

② 盒子模型

1.margin、padding、border這三個屬性。

2.伸縮盒相關內容。

3.Multi-column Layout Module多列佈局模型。

③ 文本字體

1.強制換行與不換行,清除空白。

2.文本對齊、大小(如何設置chrome小於12px的字體)、縮進、轉換。

3.單位(em、rem、px等),顏色(rgb、rgba,hls)。

④ 變換、過渡和動畫

1.transform的各種取值的作用與相容性。

2.transition過渡的動畫類型,貝塞爾曲線的原理。

3.animation動畫的各種設置,@keyframes規則。

4.瀏覽器的重繪與重排。

⑤ 選擇器

1.選擇器的分類,權值和優先順序。

2.有哪些屬性可以被繼承,哪些屬性沒法繼承。

3.偽類和偽元素分別是什麼,有什麼作用。

上面這些都是基礎的東西,除了這些基礎的內容之外需要瞭解Less、Sass、stylus等css預處理器,這將會大幅度提升你的css開發效率,也需要瞭解一下Autoprefixer、PostCSS等css後處理器。

 

3、JavaScript部分

在這裡就不說js的基礎知識了,我把js按照語法的層次和使用的層次分為了兩大塊。

按照語法的層次來說:

首先是javascript的面向對象方面的內容:在javascript中實現封裝、繼承和多態。

① 封裝:在js中可以通過閉包、作用域和作用域鏈來實現封裝,ES6的const、let的作用。

② 繼承:基於原型鏈的繼承、基於構造函數的繼承、組合式繼承、寄生式繼承等,外加ES6的class關鍵字,prototype和__proto__。

③ 多態:在javascript中多態是使用arguments來實現的,關於arguments會引申出來很多內容:

1.arguments的caller、callee等方法的作用。

2.方法的apply和call的作用和不同。

3.使用Array.prototype.slice.call來把一個數組對象轉化為數組。

4.array的各種方法,如shift、splice、push、filter、map、reduce、forEach等等。

然後是Js的設計模式,比如說那三種工廠模式啊,建造者模式啊等等。

最後是在不同情況下的this分別都代表什麼。

按照使用的層次來說:

首先最主要的就是ajax,ajax的原理,ajax跨域的方法:jsonp、使用iframe的location.hash、postMessageAPI、websocket、伺服器代理等等。

然後是tcp協議、udt協議以及http協議的協議頭、狀態碼等內容。瀏覽器的緩存,客戶端存儲方面的內容:localstorage、sessionstorage、indexDB、cookie等等。

最後是一些新的js的API,例如文件讀取(fileReader)、fetch、Promise、Web Sockets等等內容,可以去caniuse上面看一下有哪些新的東西。

小編也在前端混了有幾年,整理了一些學習資料,對web開發技術感興趣的同學
歡迎加入新建的Q群:603985993,不管你是小白還是大牛我都歡迎,希望大家誠心交流!
還有大牛整理的一套高效率學習路線和教程與您免費分享,與企業需求同步。
好友都在裡面學習交流,每天都會有大牛定時講解前端技術!

上面我所說的這些只是一些比較籠統的概念,把前端html、css和javascript所需要掌握的部分內容列舉了一下,在前端領域還有很多需要我們知道的知識,這需要大家在學習工作的過程中去自己總結。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • hash 計算與整個項目的構建相關;chunkhash 計算與同一 chunk 內容相關;contenthash 計算與文件內容本身相關。 ...
  • `webpackChunkName` 是為預載入的文件取別名,`webpackPrefetch` 會在瀏覽器閑置下載文件,`webpackPreload` 會在父 chunk 載入時並行下載文件。 ...
  • `filename` 指**列在** `entry` 中,打包後輸出的文件的名稱。`chunkFilename` 指**未列在** `entry` 中,卻又需要被打包出來的文件的名稱。 ...
  • 說實話我剛開始看 webpack 文檔的時候,對這 3 個名詞雲里霧裡的,感覺他們都在說打包文件,但是一會兒 chunk 一會兒 bundle 的,逐漸就迷失在細節里了,所以我們要跳出來,從巨集觀的角度來看這幾個名詞。 ...
  • 本項目演示地址:https://husilang.github.io/zm-ui 項目參考文章:從零開始搭建Vue組件庫 VV-UI 項目的初衷是學習怎麼封裝一個基於Vue的UI組件庫,順便記錄每個步驟,以及在此過程中遇到的難點及體會。 下麵是我個人的一個項目搭建流程,希望能幫助大家。 ①腳手架初始 ...
  • # 3.border和background - border-radius border-radius:上左 上右 下右 下左 border-radius:上左下右 上右下左 border-radius:上左 上右下左 下右 border-top-left-radius:10px 10px; bor ...
  • 常用 "CSS選擇器" 查看地址 (https://www.cnblogs.com/hleisurely/p/12836777.html) 1.選擇器的優先順序 !important的優先順序別最高 權重值為1111 用來提升某個直接選中標簽的選擇器中某個屬性的優先順序的,可以將被指定的屬性的優先順序提升為 ...
  • 前言 Deno 已經正式發佈了! 我說這句話時候,是不是很多前端 和 NodeJS 工(碼)程(農)師已經按不住自己的40米大刀了。心中的不僅感慨前端是真的會造輪子,有了 node 還不夠嗎,還沒學會 node 又搞了個 deno,node 和 deno 啥區別?! 的確,deno 和 node 形 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...