Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 中文字幕在线一区二区在线,久久天堂电影,最近中文字幕完整在线看一

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          徹底搞清楚javascript中的require、import和export

          什么有模塊概念

          理想情況下,開發者只需要實現核心的業務邏輯,其他都可以加載別人已經寫好的模塊。

          但是,Javascript不是一種模塊化編程語言,在es6以前,它是不支持”類”(class),所以也就沒有”模塊”(module)了。

          首發文章,歡迎關注我的公眾號:Web前端Talk
          

          require時代

          Javascript社區做了很多努力,在現有的運行環境中,實現”模塊”的效果。

          原始寫法

          模塊就是實現特定功能的一組方法。

          只要把不同的函數(以及記錄狀態的變量)簡單地放在一起,就算是一個模塊。



          上面的函數m1()和m2(),組成一個模塊。使用的時候,直接調用就行了。

          這種做法的缺點很明顯:”污染”了全局變量,無法保證不與其他模塊發生變量名沖突,而且模塊成員之間看不出直接關系。

          對象寫法

          為了解決上面的缺點,可以把模塊寫成一個對象,所有的模塊成員都放到這個對象里面



          上面的函數m1()和m2(),都封裝在module1對象里。使用的時候,就是調用這個對象的屬性



          這樣的寫法會暴露所有模塊成員,內部狀態可以被外部改寫。比如,外部代碼可以直接改變內部計數器的值。



          立即執行函數寫法

          使用”立即執行函數”(Immediately-Invoked Function Expression,IIFE),可以達到不暴露私有成員的目的



          使用上面的寫法,外部代碼無法讀取內部的_count變量。



          module就是Javascript模塊的基本寫法。

          主流模塊規范

          在es6以前,還沒有提出一套官方的規范,從社區和框架推廣程度而言,目前通行的javascript模塊規范有兩種:CommonJS 和 AMD

          CommonJS規范



          2009年,美國程序員Ryan Dahl創造了node.js項目,將javascript語言用于服務器端編程。

          這標志”Javascript模塊化編程”正式誕生。前端的復雜程度有限,沒有模塊也是可以的,但是在服務器端,一定要有模塊,與操作系統和其他應用程序互動,否則根本沒法編程。

          node編程中最重要的思想之一就是模塊,而正是這個思想,讓JavaScript的大規模工程成為可能。模塊化編程在js界流行,也是基于此,隨后在瀏覽器端,requirejs和seajs之類的工具包也出現了,可以說在對應規范下,require統治了ES6之前的所有模塊化編程,即使現在,在ES6 module被完全實現之前,還是這樣。

          在CommonJS中,暴露模塊使用module.exports和exports,很多人不明白暴露對象為什么會有兩個,后面會介紹區別

          在CommonJS中,有一個全局性方法require(),用于加載模塊。假定有一個數學模塊math.js,就可以像下面這樣加載。



          然后,就可以調用模塊提供的方法:



          正是由于CommonJS 使用的require方式的推動,才有了后面的AMD、CMD 也采用的require方式來引用模塊的風格

          AMD規范



          有了服務器端模塊以后,很自然地,大家就想要客戶端模塊。而且最好兩者能夠兼容,一個模塊不用修改,在服務器和瀏覽器都可以運行。

          但是,由于一個重大的局限,使得CommonJS規范不適用于瀏覽器環境。還是上一節的代碼,如果在瀏覽器中運行,會有一個很大的問題



          第二行math.add(2, 3),在第一行require(‘math’)之后運行,因此必須等math.js加載完成。也就是說,如果加載時間很長,整個應用就會停在那里等。

          這對服務器端不是一個問題,因為所有的模塊都存放在本地硬盤,可以同步加載完成,等待時間就是硬盤的讀取時間。但是,對于瀏覽器,這卻是一個大問題,因為模塊都放在服務器端,等待時間取決于網速的快慢,可能要等很長時間,瀏覽器處于”假死”狀態。

          因此,瀏覽器端的模塊,不能采用”同步加載”(synchronous),只能采用”異步加載”(asynchronous)。這就是AMD規范誕生的背景。

          AMD是”Asynchronous Module Definition”的縮寫,意思就是”異步模塊定義”。它采用異步方式加載模塊,模塊的加載不影響它后面語句的運行。所有依賴這個模塊的語句,都定義在一個回調函數中,等到加載完成之后,這個回調函數才會運行。

          模塊必須采用特定的define()函數來定義。



          • id:字符串,模塊名稱(可選)
          • dependencies: 是我們要載入的依賴模塊(可選),使用相對路徑。,注意是數組格式
          • factory: 工廠方法,返回一個模塊函數

          如果一個模塊不依賴其他模塊,那么可以直接定義在define()函數之中。



          如果這個模塊還依賴其他模塊,那么define()函數的第一個參數,必須是一個數組,指明該模塊的依賴性。



          當require()函數加載上面這個模塊的時候,就會先加載Lib.js文件。

          AMD也采用require()語句加載模塊,但是不同于CommonJS,它要求兩個參數:



          第一個參數[module],是一個數組,里面的成員就是要加載的模塊;第二個參數callback,則是加載成功之后的回調函數。如果將前面的代碼改寫成AMD形式,就是下面這樣:



          math.add()與math模塊加載不是同步的,瀏覽器不會發生假死。所以很顯然,AMD比較適合瀏覽器環境。

          目前,主要有兩個Javascript庫實現了AMD規范:require.js和curl.js。

          CMD規范



          CMD (Common Module Definition), 是seajs推崇的規范,CMD則是依賴就近,用的時候再require。它寫起來是這樣的:



          CMD與AMD一樣,也是采用特定的define()函數來定義,用require方式來引用模塊



          • id:字符串,模塊名稱(可選)
          • dependencies: 是我們要載入的依賴模塊(可選),使用相對路徑。,注意是數組格式
          • factory: 工廠方法,返回一個模塊函數



          如果一個模塊不依賴其他模塊,那么可以直接定義在define()函數之中。



          注意:帶 id 和 dependencies 參數的 define 用法不屬于 CMD 規范,而屬于 Modules/Transport 規范。

          CMD與AMD區別

          AMD和CMD最大的區別是對依賴模塊的執行時機處理不同,而不是加載的時機或者方式不同,二者皆為異步加載模塊。

          AMD依賴前置,js可以方便知道依賴模塊是誰,立即加載;

          而CMD就近依賴,需要使用把模塊變為字符串解析一遍才知道依賴了那些模塊,這也是很多人詬病CMD的一點,犧牲性能來帶來開發的便利性,實際上解析模塊用的時間短到可以忽略。

          現階段的標準


          ES6標準發布后,module成為標準,標準使用是以export指令導出接口,以import引入模塊,但是在我們一貫的node模塊中,我們依然采用的是CommonJS規范,使用require引入模塊,使用module.exports導出接口。

          export導出模塊

          export語法聲明用于導出函數、對象、指定文件(或模塊)的原始值。

          注意:在node中使用的是exports,不要混淆了

          export有兩種模塊導出方式:命名式導出(名稱導出)和默認導出(定義式導出),命名式導出每個模塊可以多個,而默認導出每個模塊僅一個。



          • name1… nameN-導出的“標識符”。導出后,可以通過這個“標識符”在另一個模塊中使用import引用
          • default-設置模塊的默認導出。設置后import不通過“標識符”而直接引用默認導入
          • -繼承模塊并導出繼承模塊所有的方法和屬性
          • as-重命名導出“標識符”
          • from-從已經存在的模塊、腳本文件…導出

          命名式導出

          模塊可以通過export前綴關鍵詞聲明導出對象,導出對象可以是多個。這些導出對象用名稱進行區分,稱之為命名式導出。



          我們可以使用*和from關鍵字來實現的模塊的繼承:



          模塊導出時,可以指定模塊的導出成員。導出成員可以認為是類中的公有對象,而非導出成員可以認為是類中的私有對象:



          模塊導出時,我們可以使用as關鍵字對導出成員進行重命名:



          注意,下面的語法有嚴重錯誤的情況:



          export在導出接口的時候,必須與模塊內部的變量具有一一對應的關系。直接導出1沒有任何意義,也不可能在import的時候有一個變量與之對應

          export a 雖然看上去成立,但是a的值是一個數字,根本無法完成解構,因此必須寫成export {a}的形式。即使a被賦值為一個function,也是不允許的。而且,大部分風格都建議,模塊中最好在末尾用一個export導出所有的接口,例如:



          默認導出

          默認導出也被稱做定義式導出。命名式導出可以導出多個值,但在在import引用時,也要使用相同的名稱來引用相應的值。而默認導出每個導出只有一個單一值,這個輸出可以是一個函數、類或其它類型的值,這樣在模塊import導入時也會很容易引用。



          命名式導出與默認導出

          默認導出可以理解為另一種形式的命名導出,默認導出可以認為是使用了default名稱的命名導出。

          下面兩種導出方式是等價的:



          export使用示例

          使用名稱導出一個模塊時:



          在另一個模塊(腳本文件)中,我們可以像下面這樣引用:



          使用默認導出一個模塊時:



          在另一個模塊(腳本文件)中,我們可以像下面這樣引用,相對名稱導出來說使用更為簡單:



          import引入模塊

          import語法聲明用于從已導出的模塊、腳本中導入函數、對象、指定文件(或模塊)的原始值。

          import模塊導入與export模塊導出功能相對應,也存在兩種模塊導入方式:命名式導入(名稱導入)和默認導入(定義式導入)。

          import的語法跟require不同,而且import必須放在文件的最開始,且前面不允許有其他邏輯代碼,這和其他所有編程語言風格一致。



          • name-從將要導入模塊中收到的導出值的名稱
          • member, memberN-從導出模塊,導入指定名稱的多個成員
          • defaultMember-從導出模塊,導入默認導出成員
          • alias, aliasN-別名,對指定導入成員進行的重命名
          • module-name-要導入的模塊。是一個文件名
          • as-重命名導入成員名稱(“標識符”)
          • from-從已經存在的模塊、腳本文件等導入

          命名式導入

          我們可以通過指定名稱,就是將這些成員插入到當作用域中。導出時,可以導入單個成員或多個成員:

          注意,花括號里面的變量與export后面的變量一一對應



          通過*符號,我們可以導入模塊中的全部屬性和方法。當導入模塊全部導出內容時,就是將導出模塊(’my-module.js’)所有的導出綁定內容,插入到當前模塊(’myModule’)的作用域中:



          導入模塊對象時,也可以使用as對導入成員重命名,以方便在當前模塊內使用:



          導入多個成員時,同樣可以使用別名:



          導入一個模塊,但不進行任何綁定:



          默認導入

          在模塊導出時,可能會存在默認導出。同樣的,在導入時可以使用import指令導出這些默認值。

          直接導入默認值:



          也可以在命名空間導入和名稱導入中,同時使用默認導入:



          import使用示例



          default關鍵字



          在import的時候,可以這樣用:



          這個語法糖的好處就是import的時候,可以省去花括號{}。

          簡單的說,如果import的時候,你發現某個變量沒有花括號括起來(沒有*號),那么你在腦海中應該把它還原成有花括號的as語法。

          所以,下面這種寫法你也應該理解了吧:



          import后面第一個$是{defalut as $}的替代寫法。

          as關鍵字

          as簡單的說就是取一個別名,export中可以用,import中其實可以用:



          上面這段代碼,export的時候,對外提供的接口是fun,它是a.js內部a這個函數的別名,但是在模塊外面,認不到a,只能認到fun。

          import中的as就很簡單,就是你在使用模塊里面的方法的時候,給這個方法取一個別名,好在當前的文件里面使用。之所以是這樣,是因為有的時候不同的兩個模塊可能通過相同的接口,比如有一個c.js也通過了fun這個接口:



          如果在b.js中同時使用a和c這兩個模塊,就必須想辦法解決接口重名的問題,as就解決了。

          CommonJS中module.exports 與 exports的區別

          Module.exports

          module.exports對象是由模塊系統創建的。 有時這是難以接受的;許多人希望他們的模塊成為某個類的實例。 為了實現這個,需要將期望導出的對象賦值給module.exports。 注意,將期望的對象賦值給exports會簡單地重新綁定到本地exports變量上,這可能不是你想要的。

          exports變量是在模塊的文件級別作用域內有效的,它在模塊被執行前被賦于 module.exports 的值。它有一個快捷方式,以便 module.exports.f = … 可以被更簡潔地寫成exports.f = …。 注意,就像任何變量,如果一個新的值被賦值給exports,它就不再綁定到module.exports(其實是exports.屬性會自動掛載到沒有命名沖突的module.exports.屬性)

          從Api文檔上面的可以看出,從require導入方式去理解,關鍵有兩個變量(全局變量module.exports,局部變量exports)、一個返回值(module.exports)



          demo.js:



          注意:

          每個js文件一創建,都有一個var exports = module.exports = {},使exports和module.exports都指向一個空對象。

          module.exports和exports所指向的內存地址相同

          者:櫻桃小丸子兒

          鏈接:https://www.jianshu.com/p/2273c8d2ef02

          Javascript

          介紹js有哪些內置對象?

          Object 是 JavaScript 中所有對象的父對象

          數據封裝類對象:Object、Array、Boolean、Number 和 String

          其他對象:Function、Arguments、Math、Date、RegExp、Error

          說出一些寫Javascript的基本規范

          1.不要在同一行聲明多個變量。

          2.請使用 ===/!==來比較true/false或者數值

          3.使用對象字面量替代new Array這種形式

          4.不要使用全局函數。

          5.Switch語句必須帶有default分支

          6.函數不應該有時候有返回值,有時候沒有返回值。

          7.For循環必須使用大括號

          8.If語句必須使用大括號

          9.for-in循環中的變量 應該使用var關鍵字明確限定作用域,從而避免作用域污染。

          10.命名規則中構造器函數首字母大寫,如function Person(){}

          11.寫注釋。

          Javascript有幾種類型的值?你能畫一下他們的內存圖嗎?

          數據類型分為兩大類:堆和棧

          棧:原始數據類型(Undefined,Null,Boolean,Number、String)

          堆:引用數據類型(對象、數組和函數)

          兩種類型的區別是:存儲位置不同;原始數據類型直接存儲在棧(stack)中的簡單數據段,占據空間小、大小固定,屬于被頻繁使用數據,所以放入棧中存儲;引用數據類型存儲在堆(heap)中的對象,占據空間大、大小不固定,如果存儲在棧中,將會影響程序運行的性能;

          引用數據類型在棧中存儲了指針,該指針指向堆中該實體的起始地址。當解釋器尋找引用值時,會首先檢索其在棧中的地址,取得地址后從堆中獲得實體。

          JavaScript創建對象的幾種方式?

          1.對象字面量的方式p={};

          2.用function來模擬無參的構造函數,再定義屬性;

          3.用function模擬構造函數,利用this;

          4.利用工廠方式(內置對象Object);

          5.利用原型方式來創建;

          6.混合方式來創建。

          JavaScript作用鏈域

          當代碼在一個環境中執行時,會創建變量對象的一個作用域鏈。如果是個函數,則將其活動對象作為變量對象。活動對象在最開始只包含一個arguments對象。而下一個變量對象則來自下一個包含環境。如此一直延續到全局執行環境,這種組織形式即為作用域鏈。內部函數可訪問外部變量,外部變量無法訪問內部函數。注意:js沒有塊級作用域,若要形成塊級作用域,可通過(function(){})();立即執行的形式實現。

          JavaScript 開發進階:理解 JavaScript 作用域和作用域鏈

          ["1","2","3"].map(parseint)答案是多少?

          [1, NaN, NaN]

          parseInt() 函數可解析一個字符串,并返回一個整數。需要兩個參數 (val, radix),

          其中 radix 表示解析時用的基數。

          map 傳了 3 個 (element, index, array),對應的 radix 不合法導致解析失敗。

          ["1","2","3"].map(parseint)

          算出字符串中出現次數最多的字符是什么,出現了多少次

          var str = "adadfdfseffserfefsefseeffffftsdg";
          var maxLength = 0;
          var result = "";
          while(str != ''){
           oldStr = str;
           str = str.replace(new RegExp(str.charAt(0),"g"),"");
           if( oldStr.length-str.length > maxLength){
           maxLength = oldStr.length-str.length;
           result = getStr + "=" + maxLength;
           }
          }
          alert(result);
          

          編寫一個方法 求一個字符串的字節長度

          <script language=”javascript”type=”text/javascript”> 
          new function(s) // s指最后括號中的參數
          { 
           if(!arguments.length||!s) 
          //arguments指最下面括號中的參數集, .length指此集合的參數個數 
          //如果最下面括號中是("你好abc","哈哈"),
          那么arguments={"你好abc","哈哈"}, .length=2
          //!s 表示參數是否非空
          return null;
           if(""==s) 
          return 0; 
           var l=0; 
           for(var i=0;i<s.length;i++) 
          //中文的值都是大于255的,所以“你好”為4個字節,
          //可以測試:alert(s.charCodeAt(i));
          { 
           if(s.charCodeAt(i)>255) l+=2; else l++;
           } 
          alert(l); 
           }
          ("hello你好,我好,大家好!world!");
           </script>
          

          JavaScript中有一個函數,執行對象查找的時候,永遠不會去查找原型,這個函數是?

          Object.hasOwnProperty(proName)

          其中參數object是必選項,一個對象的實例。

          proName是必選項,一個屬性名稱的字符串值。

          hasOwnProperty 函數方法是返回一個布爾值,指出一個對象是否具有指定名稱的屬性。此方法無法檢查該對象的原型鏈中是否具有該屬性;該屬性必須是對象本身的一個成員。如果 object 具有指定名稱的屬性,那么JavaScript中hasOwnProperty函數方法返回 true,反之則返回 false。

          頁面編碼和被請求資源的編碼如果不一致怎么處理?

          a.html 的編碼是gbk或gb2312的。 而引入的js編碼為utf-8的 ,那就需要在引入的時候加上

          <script src="http://www.xxx.com/test.js"charset="utf-8"></script>

          同理,如果你的頁面是utf-8的,引入的js是gbk的,那么就需要加上charset="gbk"

          模塊化開發怎么做?

          模塊化就是將js文件按照功能分離,根據需求引入不同的文件中。源于服務器端。

          在ES6中提出用工具babel,webpack打包成瀏覽器識別的js來實現模塊化開發,不同的框架和庫的模塊,有很多功能類似比如Node.js中的模塊,Angular.js中的模塊,React.js中的模塊,只要接口Api可以對的上,那么也可以通用。

          其他

          網站重構的理解?

          網站重構:在不改變外部行為的前提下,簡化結構、添加可讀性,而在網站前端保持一致的行為。也就是說是在不改變UI的情況下,對網站進行優化,在擴展的同時保持一致的UI。

          對于傳統的網站來說重構通常是:

          表格(table)布局改為DIV+CSS

          使網站前端兼容于現代瀏覽器(針對于不合規范的CSS、如對IE6有效的)

          對于移動平臺的優化

          針對于SEO進行優化

          深層次的網站重構應該考慮的方面

          減少代碼間的耦合

          讓代碼保持彈性

          嚴格按規范編寫代碼

          設計可擴展的API

          代替舊有的框架、語言(如VB)

          增強用戶體驗

          通常來說對于速度的優化也包含在重構中

          壓縮JS、CSS、image等前端資源(通常是由服務器來解決)

          程序的性能優化(如數據讀寫)

          采用CDN來加速資源加載

          對于JS DOM的優化

          HTTP服務器的文件緩存

          AMD和CMD 規范的區別?

          AMD規范是 RequireJS 在推廣過程中對模塊定義的規范化產出的,而CMD規范是SeaJS 在推廣過程中對模塊定義的規范化產出的。這些規范的目的都是為了 JavaScript 的模塊化開發,特別是在瀏覽器端的。

          主要區別總結為以下三條

          1、CMD推崇依賴就近,而AMD推崇依賴前置

          2、執行順序上: CMD是延遲執行的,而AMD是提前執行的。

          3、api設計角度上:AMD 的 API 默認是一個當多個用,CMD 的 API 嚴格區分,推崇職責單一。比如 AMD 里,require 分全局 require 和局部 require,都叫 require。CMD 里,沒有全局 require,而是根據模塊系統的完備性,提供 seajs.use 來實現模塊系統的加載啟動。CMD 里,每個 API 都簡單純粹。

          一個頁面從輸入 URL 到頁面加載顯示完成,這個過程中都發生了什么?(流程說的越詳細越好)

          分為4個步驟:

          ①當發送一個URL請求時,不管這個URL是Web頁面的URL還是Web頁面上每個資源的URL,瀏覽器都會開啟一個線程來處理這個請求,同時在遠程DNS服務器上啟動一個DNS查詢。這能使瀏覽器獲得請求對應的IP地址。

          ②瀏覽器與遠程Web服務器通過TCP三次握手協商來建立一個TCP/IP連接。該握手包括一個同步報文,一個同步-應答報文和一個應答報文,這三個報文在 瀏覽器和服務器之間傳遞。該握手首先由客戶端嘗試建立起通信,而后服務器應答并接受客戶端的請求,最后由客戶端發出該請求已經被接受的報文。

          ③一旦TCP/IP連接建立,瀏覽器會通過該連接向遠程服務器發送HTTP的GET請求。遠程服務器找到資源并使用HTTP響應返回該資源,值為200的HTTP響應狀態表示一個正確的響應。

          ④此時,Web服務器提供資源服務,客戶端開始下載資源。

          請求返回后,便進入了我們關注的前端模塊,簡單來說,瀏覽器會解析HTML生成DOM Tree,其次會根據CSS生成CSS Rule Tree,而javascript又可以根據DOM API操作DOM。

          WEB應用從服務器主動推送Data到客戶端有那些方式?

          JavaScript數據推送

          Commet:基于HTTP長連接的服務器推送技術

          基于WebSocket的推送方案

          SSE(Server-Send Event):服務器推送數據新方式

          者 | 六小登登

          責編 | 屠敏

          從 2013 年專科畢業開始,一路跌跌撞撞走了很多彎路,做過餐廳服務員,進過工廠干過流水線,做過客服,干過電話銷售可以說經歷相當的“豐富”。

          最后的機緣巧合下,走上了前端開發之路,作為一個非計算機專業且低學歷的人來說,自學編程其實不是件容易的事情,不過慶幸的是自己堅持下來了。

          目前工作還算不錯,收入在目前所在的城市不算高,不算低,生活也還過得去,繼續加油努力,也希望自己在今后更上一層。

          從 2016 年下半年開始,我真正接觸前端,到現在 2 年多的時間。開始之初,我沒有任何的語言基礎,完全從零的小白開始,就連「對象」我都弄不明白,更別說那些高深莫測的什么封裝、繼承、多態等。

          當時自己也不知從何入手,怎么辦呢?于是每當自己遇到困難時,就厚著臉皮去請教前輩大牛,然后就是去查閱資料,很多時候自己也很覺得不好意思,現在才發現人很多時候都恥于相別人請教,怕自己丟面子。

          但作為一個過來人,我要告訴你請教前輩大牛真的很重要,可以讓你少走很多的彎路,不要怕丟人,沒面子,面子值幾個錢?學到真本事才最重要。沒有技能才叫真的沒有面子。當然了我們在請教別人時,一定要掌握「度」,不要打擾到了別人的工作。

          我現在非常感謝前輩們的賜教,也感謝那些在網上寫博客、文章分享的大牛們,給了我們這些自學的小白很多的資料,經驗,心得。從中受益很多。

          向優秀的前輩們學習,我開始寫博客,希望也能幫到和我一樣,學渣、從零開始、喜歡技術的一群志同道合的人。

          我深知自己的技術并不高,還處在繼續學習的路上,離大牛還差的很遠,我本身也非常敬畏技術,也知道自己的渺小,只希望這篇文章的「學習之路」對于那些「從零開始」學習前端的同學有一些指引作用,不像自己一開始那樣的那么盲目,哪怕對你有一點點的幫助,就足夠了。

          說了這么多,下面我們直接進入正題,都是我平時學習和收集的一些資料希望能夠幫到你。

          前言

          1. 首先我得告訴你,自學是件很苦的事情,學習本身就是件反人性的過程,更何況在一個從零開始的全新領域獨自奮斗,這里不是要打擊你,而是要你認真想好,結合自身的環境、條件。不然半途而廢浪費的不僅是時間,還有精力、金錢。
          2. 如果你已經想好決定去做,那就不要猶豫,堅持下去你就可以成功,像我這樣的學渣都可以,你沒有什么不可以的,一定要相信自己。
          3. 興趣是最好的老師,很多人對這句話非常反感,被生活所迫,談興趣不可笑嗎?其實不是,問問自己對技術有沒有興趣,做自己喜歡和感興趣的事情才能夠走的更遠和更久,很多人不理解這一點,總有一天你會明白的,我當時轉前端的時候也是因為自己挺喜歡,而且最接近用戶,都是所見所得的東西很好玩,另外一方面也覺得工資也挺高,所以自己打心里覺得做前端挺好。
          4. 做好持續學習,時刻保持學習的心態,說實話現在社會,科技的發展非常之快,技術的更新更是如此,如果你覺得學習一門技術就可以吃到老,我勸你還是打住,可能考個公務員更適合你(不要杠精,我并不是說公務員不要學習,自己體會就好)。
          5. 永遠不要覺得遲,只要行動然后堅持下去,你就干掉了 80% 的人,自學的人很多,但是堅持下來的沒有幾個。就像郭德綱說過,不是我的相聲說的多好而是我活了下來。著名營銷人員「小馬宋」畢業時燒了很多年的鍋爐,但是自己對廣告營銷感興趣,所以離職從零開始,現在已經是很有名的營銷大師。
          6. 與其把時間花在學與不學的糾結上,不如把這個時間放在行動上,如果發現自己不合適也堅持不下去,那就換個賽道,專注的去做一件事情,會提高你的成功概率。

          工具篇

          工欲善其事,必先利其器,所以在開始之前選擇一個合適好用的編輯器是很重要的,工具不再多,在于好用就行,除了編輯器,我們也要掌握其他的一些工具,才能夠讓我們在學習的道路上更加的順暢。

          1. WebStorm

          不必多說,前端最強大的編輯器,特別是那無敵的智能提示,但是它的缺點在于如果項目多于大時,出現的卡頓讓很多人苦惱。

          • WebStorm 官網下載地址:https://www.jetbrains.com/webstorm/。
          • WebStorm 有哪些過人之處?(https://www.zhihu.com/question/20936155)
          • 激活 WebStorm2018(https://blog.csdn.net/qq_32135281/article/details/82696280)

          2. Visual Studio Code

          微軟開源免費產品,受到非常多技術人員的喜愛,基本上成為前端開發者的必備編輯器,強大的插件擴展,可以靈活的打造自己喜歡的風格。給你們送上常用插件列表拿走不謝。

          • Visual Studio Code 官網下載地址:https://code.visualstudio.com/。
          • VSCode 拓展推薦:https://github.com/varHarrie/varharrie.github.io/issues/10
          • 使用頂級 VSCode 擴展來加快開發 JavaScript:https://www.html.cn/archives/9507
          • vscode 插件推薦:https://segmentfault.com/a/1190000006697219

          3. atom

          也是一款免費開源的編輯器,受到很多人的喜愛,但是我本人用的較少,所以插件方面就不推薦了,大家可以按照自己的愛好去尋找。

          4. 科學上網

          每個程序員都應該具備的工具和能力,否則很多事情都無法辦到,至于怎么做,你可以自己查閱資料,這里不就不在多說了。而且下面推薦的很多資源都是需要科學上網之后才能訪問,所以一定要學會。

          5. Google

          在使用「Google」之前必須學會科學上網,不然無法訪問,學會使用搜索可以幫助我們解決很多問題,一個人的知識是有限的,掌握了搜索的技巧才能以不變應萬變,很多時候百度出來的東西重復性很大,最重要的是垃圾信息很多,在百度找不到的答案,在這里很容易找到,Google 是我的必備搜索。

          6. Github

          全球最大的「同性」開源交流社區,沒有賬號的趕緊注冊,在這有很多優秀的資源項目,各種大神。觀摩優秀代碼是我們學習的很好路徑。另外在開發過程中,很多時候任務重、時間緊,應該避免重復造輪子,這里能夠找到你需要的工具或代碼。

          7. Stack Overflow

          國外著名的技術問答交流社區,開發時碰到的很多問題在這里都能找到答案。

          8. SegmentFault

          對應的國內版的技術問答交流社區,如果你英文不好,也可以在這里找找答案。

          9. Markdown

          Markdown 輕量級標記語言,簡潔的語法,讓作者專注內容而非復雜的格式要求,我認為人人都應該掌握,特別是經常寫博客的人。想想你在用 world 時的場景,每次寫完文章之后,不得不話費很多時間進行格式的排版,使用它你就可以避免這些煩惱。

          • Markdown 中文文檔:https://markdown-zh.readthedocs.io/en/latest/

          HTML 篇

          一些準備就緒之后,開始我們的學習之旅,首先我們先從 HTML 開始。

          HTML名為「超文本標記語言」,是整個頁面的結構基礎,它承載了我們的頁面內容。

          1. 基礎

          • w3school 在線教程(http://www.w3school.com.cn/h.asp):內容非常的基礎,適合小白學習,對 HTML 有一個入門了解。
          • freeCodeCamp(https://www.freecodecamp.cn/):一個非常好的入門學習網站,采用闖關的模式,就像游戲打怪升級一樣,非常的有樂趣,準備自學的小伙伴不妨試試。

          2. 進階

          • MDN HTML(https://developer.mozilla.org/zh-CN/docs/Web/HTML):這里的內容質量更好,錯誤更少,內容也更加的全面。
          • HTML 和 CSS 編碼規范(https://codeguide.bootcss.com/):掌握一些代碼技巧,寫出更好,更高質量的代碼。

          CSS 篇

          HTML 承載了頁面的內容,但是有時候會略顯單調與「丑陋」,CSS 的作用就是為這些內容加上樣式,就像一個美女也要有漂亮的外衣去修飾才會更加漂亮,「人靠衣裝馬靠鞍」,網頁的內容也是需要穿上一件漂亮的外衣去吸引用戶。而 CSS 則完成了這個裝飾。

          1. 基礎

          • 學習 CSS 布局(http://zh.learnlayout.com/):帶你一步一步的完成 CSS 的學習。
          • CSS 參考手冊(https://css.doyoe.com/):對CSS可以有一個全面入門的學習。
          • w3school CSS 參考手冊(http://www.w3school.com.cn/cssref/index.asp):同上也是非常基礎的知識,適合入門。

          2. 進階

          書籍:

          《CSS揭秘》(https://book.douban.com/subject/26745943/):非常推薦的一本 CSS 書籍,可以學到很多鮮為人知的技巧。

          在線系列:

          • MDN CSS(https://developer.mozilla.org/zh-CN/docs/Web/CSS):和 HTML 都是 MDN 社區文檔,質量保障。
          • HTML和CSS編碼規范(https://codeguide.bootcss.com/):掌握一些代碼技巧,寫出更好,更高質量的代碼。
          • 大漠老師的CSS系列(https://www.w3cplus.com/CSS3):大漠老師對CSS有非常深入的認識和豐富的實踐經驗,《圖解CSS3:核心技術與案例實戰》的作者。
          • 大漠老師的SASS系列(https://www.w3cplus.com/blog/tags/302.html):大漠老師的 sass 文章系列。
          • SASS中文網(https://www.sasscss.com/):成熟、穩定、強大的 CSS 擴展語言解析器,它可以讓你使用變量,條件語句等書寫 CSS。
          • Stylus官網(https://stylus.bootcss.com/):同樣是 CSS 預編譯器,但它省去了一些符號,讓 CSS 寫起來更加的簡潔,清爽。
          • HTML5和CSS3(https://github.com/qianguyihao/Web/tree/master/07-HTML5%E5%92%8CCSS3):詳解HTML5 和 CSS3。

          知識點:

          • 別說你懂CSS相對單位(http://wuyuying.com/blog/archives/css-in-depth-relative-units/):深入了解 CSS 的相對單位rem,em區別。
          • CSS 進階內容(https://github.com/coconilu/Blog/issues/29):常見知識點的深入了解。
          • Flex 布局教程:語法篇(http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html):阮一峰老師的flex講解。
          • Flex 布局教程:實例篇(http://www.ruanyifeng.com/blog/2015/07/flex-examples.html):阮一峰老師的flex講解。
          • “CSS相關”目錄存檔(https://www.zhangxinxu.com/wordpress/category/css/):張鑫旭大佬的CSS系列文章,深入淺出,《CSS世界》作者。
          • CSS繪制的40種形狀和圖形(http://www.open-open.com/lib/view/open1476240478941.html):利用CSS繪制出的40各種圖形形狀。
          • CSS-大前端(http://www.daqianduan.com/tag/css):一些 CSS 的知識點。

          JavaScript 篇

          有了 HTML 與 CSS,網頁也就有了內容和樣式,但是會缺少與用戶的互動,所有的內容都靜靜的躺在那里死氣沉沉。就好比一個美女穿著漂亮的衣服在你面前一動不動好像也沒有什么吸引力,但如果又唱歌,又跳舞,還向你拋媚眼,那可真就把持不住了。JavaScript 就是給網頁添加這樣的「行為」。

          Javascript 簡史(https://blog.csdn.net/qq_32135281/article/details/81667714):可以簡單了解下,JavaScript 發展由來。

          1. 基礎

          書籍

          • 《JavaScript權威指南 (第6版)》(https://book.douban.com/subject/10549733/):俗稱「犀牛書」,JS 的經典之作,提升JS技能的必備書籍,我的JS基礎知識全都是啃這本書啃下來的,剛開始讀時可能有會有些吃力,但是只要堅持下來收獲滿滿。
          • 《JavaScript高級程序設計(第3版)》(https://book.douban.com/subject/10546125/):俗稱「紅寶書」,JavaScript 超級暢銷書,全書闡述了JavaScript語言實現的各個組成部分,ECMAScript,DOM,BOM,事件,面向對象等等,隨時拿出來翻翻,更加深入了學習 JS。

          在線系列

          除了書籍之外,也有很多優秀的在線教程,可以幫助我們更好的學習。

          • 現代 Javascript 教程(https://zh.javascript.info/):非常全面的JavaScript 學習教程,從基礎到高階,非常詳細,相信你會愛上它的。
          • 廖雪峰的JavaScript教程(https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000):廖雪峰系列教程。
          • JavaScript 標準參考教程(alpha)(https://javascript.ruanyifeng.com/):阮一峰老師的系列教程,通俗易懂,案例豐富。

          2. 進階

          • JavaScript語言精粹(https://github.com/qibaoguang/Study-Step-by-Step/blob/master/%E8%AF%BB%E4%B9%A6%E7%AC%94%E8%AE%B0/javascript_the_good_parts.md):揭示JavaScript中的精華。
          • JavaScript 秘密花園(http://bonsaiden.github.io/JavaScript-Garden/zh/#other.timeouts):對 JS 一些的核心知識點進行梳理講解,例如:this,閉包/作用域,構造函數,原型等等,都是面試必考知識點。
          • ECMAScript 6 入門(http://es6.ruanyifeng.com/):阮一峰老師ES6入門書籍,全面介紹 ECMAScript 6 新引入的語法特性。
          • JavaScript使用技巧(http://www.jstips.co/zh_CN/):可以認識到一些你平時沒有接觸過的小技巧。
          • 深入理解javascript原型和閉包系列(http://www.cnblogs.com/wangfupeng1988/p/4001284.html):詳細解釋了原型和閉包,看完之后對原型與閉包讓你徹底明白。
          • 大漠老師的JavaScript系列(https://www.w3cplus.com/JavaScript):大漠老師的JavaScript系列文章。
          • JavaScript 算法與數據結構(https://github.com/trekhleb/javascript-algorithms/blob/master/README.zh-CN.md):基于 JavaScript 的算法與數據結構,讓你愉快的學習。
          • JavaScript中的正則表達式(https://blog.csdn.net/qq_32135281/article/details/78274563):我自己的一篇正則表達式的文章,希望對你有幫助。
          • 30分鐘掌握ES6/ES2015核心內容(上)(https://segmentfault.com/a/1190000004365693)
          • 30分鐘掌握ES6/ES2015核心內容(下)(https://segmentfault.com/a/1190000004368132):闡述了一些常用的ES6的知識點。
          • 學用 JavaScript 設計模式(https://www.oschina.net/translate/learning-javascript-design-patterns):闡述JavaScript編程語言中經典和現代的設計模式。
          • 你不懂JS(系列叢書)(https://github.com/getify/You-Dont-Know-JS/tree/1ed-zh-CN)
          • InterviewMap(https://yuchengkai.cn/docs/frontend/#%E5%86%85%E7%BD%AE%E7%B1%BB%E5%9E%8B):聚集了很多知識點,包括JS,瀏覽器,性能等。
          • 30 秒就能理解的 JavaScript 代碼片段(https://www.html.cn/30-seconds-of-code/):讓你更好的理解一些有用的JS代碼片段。

          TypeScript篇

          ES6 的超集擴展,嚴格的數據類型,帶來更好的維護,適合大型項目的開發工作,有人說它是未來的發展趨勢,你說要不要了解?

          • TypeScript 中文手冊(https://typescript.bootcss.com/):官網翻譯版。
          • TypeScript Handbook(中文版)(https://zhongsp.gitbooks.io/typescript-handbook/content/):中文版。
          • RxJS 中文文檔(https://cn.rx.js.org/):中文官網。
          • 30 天精通 RxJS (01):認識 RxJS(https://ithelp.ithome.com.tw/articles/10186104):繁體字可能閱讀起來并沒有那么順暢。

          Jquery篇

          雖說現在已經是單頁面應用時代,有React,Vue 這種強大的框架可以使用,但也不缺乏一些老的項目需要維護,而且在學習之初,可以用它做兩個簡單的應用還是不錯的,可以相對了解下基本用法,它可以讓你更好,更方便的操作DOM。但不建議再深度學習。

          • 《鋒利的jQuery(第2版)》(https://book.douban.com/subject/10792216/):一本很不錯的 Jquery 學習書籍。
          • jQuery API中文文檔(https://www.jquery123.com/):JQuery 中文教程。

          Ajax篇

          掌握了的HTML、CSS、JavaScript時,這時候可以嘗試自己做一些項目了,而項目中肯定會有數據的交互,這時候就是 Ajax 的用武之地了。

          • 廖雪峰AJAX(https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/001434499861493e7c35be5e0864769a2c06afb4754acc6000):廖雪峰大佬的博客知識。
          • XMLHttpRequest 對象(https://wangdoc.com/javascript/bom/xmlhttprequest.html):阮一峰老師的AJAX詳解。
          • JSON風格指南(https://github.com/liuxiaodeng/free-programming-books/blob/master/free-programming-books-zh.md#javascript):前后端的交互數據通常都是 JSON 格式,所以了解 JSON 是必要的。

          NodeJS與模塊化

          NodeJs 的出現讓前端發展進入了一個新的領域,并且滋生出專業的 Node 工程師,不僅如此 Node 在前端模塊化,工程化起到很重要的作用,所以了解是必須的,如果感興趣的可以深入學習,可以向全棧工程師發展。

          • Javascript模塊化編程(一)(http://www.ruanyifeng.com/blog/2012/10/javascript_module.html):模塊的寫法
          • Javascript模塊化編程(二):AMD規范
          • Javascript模塊化編程(三):require.js的用法
          • 前端模塊化開發那點歷史(https://github.com/seajs/seajs/issues/588):了解下,前端模塊化的發展。
          • Node.js 官方(https://nodejs.org/zh-cn/)
          • 狼叔:如何正確的學習Node.js(https://github.com/i5ting/How-to-learn-node-correctly):狼叔江湖地位頗高,《更了不起的 Node.js》的作者。
          • 全棧工程師之路-Node.js(http://i5ting.github.io/nodejs-fullstack/)

          框架篇

          隨著日益復雜的用戶需求,與系統的復雜度上升,傳統的開發模式日漸的很難滿足,此時的三大框架孕育而生,讓開發者更加高效,可復用,把關注點都放在數據層的操作,免去那些繁瑣而又重復的視圖操作。

          現在框架的能力已經是前端開發人員必備的技能之一也是趨勢,三大框架的「最終目的」都是一致的,我認為開發者不必糾結于到底應該選擇哪一個學習,可以選擇其中的兩個是最好的。對于剛入門的人來說,建議選擇 Vue 入手,比較簡單,靈活。

          • MVC,MVP 和 MVVM 的圖示(http://www.ruanyifeng.com/blog/2015/02/mvcmvp_mvvm.html):在學習框架之前,你應該了解下MVVM的設計思想。
          • 框架原理(https://yuchengkai.cn/docs/frontend/framework.html):了解一些框架的基本原理。

          1. Angular

          • Angular(https://angular.cn/):Angular官方社區。
          • Angular開發者(http://www.ngfans.net/):大漠窮秋老師維護的站點,Angular中國布道者。
          • NG-ZORRO(https://ng.ant.design/docs/introduce/zh#%E8%AE%BE%E8%AE%A1%E8%A7%84%E8%8C%83):Angular UI 組件庫,阿里巴巴出品。

          2. Vue

          • Vue(https://cn.vuejs.org/index.html):官網,最好的學習資料。
          • 我的Vue進階之路(https://blog.csdn.net/qq_32135281/column/info/29689)
          • 使用vue全家桶制作博客網站(https://www.cnblogs.com/xiaohuochai/p/9228543.html)
          • Element(http://element-cn.eleme.io/#/zh-CN):一個高質量的 Vue UI 組件庫。餓了么前端團隊出品。
          • Vue 項目里戳中你痛點的問題及解決辦法(更新)(https://juejin.im/post/5b174de8f265da6e410e0b4e):做項目難免回去到坑,這里你或許可以找到答案。

          3. React

          React我了解不多,所以就沒什么好推薦的了,大家可自行學習。

          • React官網(https://www.reactjscn.com/)

          圖形可視化

          隨著日益增長的數據,如何利用高效的利用數據,是每個企業都考慮的問題,而人的眼睛看到的東西要勝過閱讀的問題,俗話說「一圖勝千言」就是這個道理,所以數據的可視化就會格外的重要,以下都是我常看的一些技術,書籍,和關注的可視化開源庫。

          • 《HTML5 Canvas核心技術》(https://book.douban.com/subject/24533314/):學習 Canvas 比較好的一本書籍。
          • Canvas系列(https://www.w3cplus.com/search/node/canvas):大漠老師的 Canvas 系列。
          • Echarts(https://www.echartsjs.com/index.html)
          • D3(https://d3js.org/)
          • Highcharts(https://www.highcharts.com.cn/)
          • AntV(https://antv.alipay.com/zh-cn/index.html)
          • Mapv(https://mapv.baidu.com/)

          工程化與版本控制篇

          1. Git

          版本控制工具,很多新手往往把 git 與 github 傻傻分不清楚,二者是不同的東西,一定要去區分清楚。

          • Git教程(https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000):廖雪峰老師的教程。
          • Learn Git Branching(https://learngitbranching.js.org/):一種有趣的學習 Git 的方式。
          • GitHub 漫游指南(https://github.com/phodal/github):作者是一個極客。
          • git - 簡易指南:http://www.bootcss.com/p/git-guide/

          2. Gulp

          自動化構建工具,項目打包部署前的壓縮合并,節省時間,提高開發效率。

          • Gulp 中文網(https://www.gulpjs.com.cn/):官方教程。
          • gulp詳細入門教程(http://www.ydcss.com/archives/18):非常詳細的實現步驟。

          3. Webpack

          Webpack 是當下最熱門的前端資源模塊化管理和打包工具。它可以將許多松散的模塊按照依賴和規則打包成符合生產環境部署的前端資源。

          • Webpack中文文檔:https://www.webpackjs.com/
          • webpack原理:https://juejin.im/entry/5b0e3eba5188251534379615
          • Webpack揭秘——走向高階前端的必經之路:https://juejin.im/post/5badd0c5e51d450e4437f07a
          • Webpack HMR 原理解析:https://zhuanlan.zhihu.com/p/30669007
          • webpack 熱加載原理探索:http://shepherdwind.com/2017/02/07/webpack-hmr-principle/

          4. Babel

          JavaScript代碼編譯器,可以讓ES6及以上語法轉換成瀏覽器支持的語法,一般會在框架的腳手架中自行配置。

          • Babel(https://babel.bootcss.com/):官網教程。

          5. 代碼質量

          • ESLint(https://eslint.bootcss.com/):javascript代碼檢測工具幫助我們寫出更規范的代碼。

          瀏覽器與HTTP

          • 瀏覽器的常見知識點(https://yuchengkai.cn/docs/frontend/browser.html):需要我們了解的常見知識。
          • 網站安全(https://yuchengkai.cn/docs/frontend/safety.html):幾種常見安全問題。
          • 同源限制(https://wangdoc.com/javascript/bom/same-origin.html)
          • 從URL輸入到頁面展現到底發生什么?(https://github.com/ljianshu/Blog/issues/24)
          • 深入理解瀏覽器的緩存機制(https://github.com/ljianshu/Blog/issues/23)
          • 網頁性能管理詳解(http://www.ruanyifeng.com/blog/2015/09/web-page-performance-in-depth.html)
          • 關于Http協議,你必須要知道的(https://github.com/ljianshu/Blog/issues/22)
          • HTTP 協議(https://github.com/coconilu/Blog/issues/135)
          • HTTP2 協議(https://github.com/coconilu/Blog/issues/134)
          • 瀏覽器同源政策及其規避方法(http://www.ruanyifeng.com/blog/2016/04/same-origin-policy.html)
          • 跨域資源共享 CORS 詳解(http://www.ruanyifeng.com/blog/2016/04/cors.html)
          • 總結 XSS 與 CSRF 兩種跨站攻擊(https://segmentfault.com/a/1190000004623125)

          性能優化

          • 性能優化(https://yuchengkai.cn/docs/frontend/performance.html):常見性能優化。
          • 前端性能優化的七大手段(https://www.cnblogs.com/xiaohuochai/p/9178390.html)
          • 延遲加載(Lazyload)三種實現方式(https://zhuanlan.zhihu.com/p/25455672)
          • 詳解懶加載和預加載(https://www.geekjc.com/post/58d94d0f16a3655650d6fafe)
          • 前端優化帶來的思考,淺談前端工程化(http://www.cnblogs.com/yexiaochai/p/4901341.html)
          • 推薦幾本與Web性能優化有關的書籍(https://w3ctech.com/topic/108)
          • vue + webpack 前端性能優化(https://juejin.im/post/5bc5c106e51d450e7a253e1b)

          SEO

          • SEO優化實戰(https://imweb.io/topic/5682938b57d7a6c47914fc00)

          博客系列

          1. 個人

          現在是一個信息爆炸的時代,網上有很多優秀的博客文章,每個人的精力都是有限的,不可能關注到所有的博客,每個人關注點可能不太一樣,所以關注的個人博客也會不同,這些推薦幾個我比較常看的幾個高質量博客。而且是持續更新的。

          • 阮一峰的個人網站(http://www.ruanyifeng.com/home.html):阮一峰老師江湖地位不必多說,博客不止有技術,現在阿里任職。
          • 廖雪峰的官方網站(https://www.liaoxuefeng.com/):廖雪峰老師寫過很多優秀的系列教程,值得去學習。
          • 張鑫旭(https://www.zhangxinxu.com/):專注前端技術的大牛之一,出版《css世界》一書。
          • W3cplus(https://www.w3cplus.com/):大漠老師在手淘任職,CSS,HTML 有著豐富的經驗。
          • 前端入門和進階學習筆記(https://github.com/qianguyihao/Web):從零開始自學,然后進入京東,記錄作者一路走來的學習筆記。
          • 六小登登(https://blog.csdn.net/qq_32135281):我自己的個人博客,記錄自己的一些學習總結,個人成長,認識思維,雖然自己還是個菜鳥,但一直在路上。

          2. 團隊

          • 奇舞周刊(https://weekly.75team.com/):收集每周前端精華文章。
          • 美團技術團隊(https://tech.meituan.com/):分享一些美團的技術路線。
          • JavaScript Weekly(https://javascriptweekly.com/):每周都會分享一些 JavaScript 優質內容。
          • 印記中文周刊(https://weekly.docschina.org/):如果你對英文有閱讀障礙的話,印記幫你翻譯。
          • 凹凸實驗室(https://aotu.io/index.html):京東團隊。
          • 淘寶前端團隊FED(http://taobaofed.org/):淘寶前端團隊,不必多說了。
          • 網易FEG前端團隊(http://feg.netease.com/):網易的前端團隊,網易的產品一直都是我最喜歡的。
          • IMWeb前端博客(https://www.imweb.io/):騰訊公司前端團隊,負責QQ的相關業務你就知道了,都是億級別。
          • tutorialzine(https://tutorialzine.com/):高質量教程和文章庫。

          項目資源

          • 前端技能匯總(http://html5ify.com/fks/):一個前端工程師需要的技能點和學習資料。
          • You-need-to-know-css(https://lhammer.cn/You-need-to-know-css/#/):一個CSS的優質項目,純 CSS 實現我們項目中很多常用,不常用的樣式。
          • JavaScript libraries(https://www.javascripting.com/):一些優秀的JavaScript 開源庫。
          • awesome-web-dev-books(https://github.com/jobbole/awesome-web-dev-books):前端經典學習書單。
          • 前端 TOP 100(https://www.awesomes.cn/rank):基本涵蓋了所有前端在用的開源項目,我覺得收藏這一個就夠了。

          常用工具

          • CSS Sprites Generator(https://www.toptal.com/developers/css/sprite-generator):雪碧圖的在線制作工具。
          • Lorem Picsum(https://picsum.photos/):好用的圖片臨時占位符。
          • Md2All(http://md.aclickall.com/):優秀的現在 Markdown 編輯器。
          • 優波設計(https://ubuuk.com/):優秀的設計導航網站,幫助你更好的尋找資料。
          • 搬書匠(http://www.banshujiang.cn/):書籍搜索下載。
          • 史萊姆導航(http://www.slimegps.cn/):資源搜索。
          • codePen(https://codepen.io/):在線代碼編輯工具。
          • Iconfont(https://www.iconfont.cn/):阿里的字體圖標庫,支持多種格式,下載圖片,在線使用,SVG等等。
          • Can I use(https://www.caniuse.com/):可以查看瀏覽器兼容 CSS 情況。
          • 在線工具(https://tool.lu/):工具資源導航。

          最后

          以上是我這兩年多一路走來收藏的一些資料,整理這份資料也花了我好幾天的時間,希望能夠在自學的道路上幫到你。

          再次聲明,我并不是什么大神,我自認為技術也沒有到達這個層級,但是我會一直堅持學下去,另外一定不要誤會這里面的知識我全部都會,這些都是我學習的一些資料想整理出來,免去小白的一些不知道如何查閱資料。

          這里的資源可能并不適合每一個人,你也不一定全部都需要,只需要挑選自己想要的部分就行,任何事情并不是越多越好。

          作者:六小登登,個人公眾號:六小登登(ID:liuxiaodengdeng)。目前在某創業公司任職前端開發工作,近 3 年前端開發經驗,愛技術、愛寫作、愛分享。

          聲明:本文為作者投稿,版權歸其個人所有。


          主站蜘蛛池模板: 亚洲国产精品乱码一区二区| 日本亚洲国产一区二区三区| 欧美一区内射最近更新| 无码av免费毛片一区二区| 无码乱码av天堂一区二区| 成人精品一区久久久久| 国产一区中文字幕在线观看| 精品国产一区二区22| 末成年女AV片一区二区| 欧美日本精品一区二区三区| 日韩一区二区三区视频| 无码人妻一区二区三区在线| 国产精品高清视亚洲一区二区| 精品综合一区二区三区| 国产suv精品一区二区33| 精品日韩亚洲AV无码一区二区三区| 亚洲AV无码一区二区三区久久精品| 国产一区二区三区在线免费观看| 国产日韩一区二区三免费高清| 日韩精品一区二区三区中文精品| 日本一区二区三区免费高清在线 | 亚洲第一区视频在线观看| 人妻av综合天堂一区| 免费日本一区二区| 国产精品亚洲综合一区在线观看 | 麻豆AV无码精品一区二区| 麻豆视频一区二区三区| 人妻少妇久久中文字幕一区二区| 日韩精品一区二区三区中文版| 另类一区二区三区| 亚洲乱码国产一区网址| 亚洲乱码一区二区三区国产精品 | 老熟妇高潮一区二区三区| 精品一区二区三区四区| 国产福利一区二区| 国产精品福利一区二区久久| 在线精品国产一区二区三区| 四虎在线观看一区二区| 91在线看片一区国产| 国模无码人体一区二区| 亚洲视频一区二区|