如今前端界angular react vue三大框架并駕齊驅(qū),其中有一個(gè)共同點(diǎn)就是組件化開發(fā),這也符合w3c 推行Web Components的趨勢。現(xiàn)如今不懂組件化開發(fā)的前端絕對不是好廚子。跳槽新公司pc端使用angular1.5的Components比較多,趁著入職前幾天自己看一下。
由于angular2.0學(xué)習(xí)曲線比較陡峭(對于我這種菜雞來說),為了讓開發(fā)者平穩(wěn)的從angular1.x 版本過渡到angular2,所以angular1.5中引入了components,需要注意的是所有components能實(shí)現(xiàn)的功能directive都能實(shí)現(xiàn)。 順便說一句1.5之前的directive感覺有點(diǎn)混亂,既包括指令又包括組件(我自己感覺指令是不應(yīng)該有dom結(jié)構(gòu)的,而組件是應(yīng)該有的)

介紹

angular1.5 Components比較適合組件化編程架構(gòu)的程序,相比于之前的指令有以下幾個(gè)優(yōu)點(diǎn)。
1.比指令的配置更加簡單
2.自帶默認(rèn)配置使之符合最佳實(shí)踐
3.更適合組件化架構(gòu)的程序
4.使用Components更符合angular發(fā)展的趨勢
當(dāng)然有些情況下不要使用Components
1.當(dāng)你想使用compile和pre-link這兩個(gè)鉤子時(shí),因?yàn)閏omponents不包含這兩個(gè)鉤子,所以component無法用于操作DOM。
2.當(dāng)你想作為屬性或者css類名調(diào)用時(shí),components只能作為自定義的HTML元素調(diào)用

使用

定義一個(gè)組件

  function HeroDetailController($scope) {
     console.log($scope)     // console.log(this.hero)}

angular.module('heroApp').component('heroDetail', {
  templateUrl: './heroDetail.html',
  controller:['$scope',HeroDetailController] ,
  bindings: {
    hero: '='
  }
});

調(diào)用組件(只能作為自定義的HTML元素調(diào)用)

        		

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運(yùn),軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動(dòng)軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式