AngularJS – Directive & Filter 介紹篇

為了方便文章閱讀,本篇將filter翻譯成過濾器、directive翻譯成指示指令

在看過前幾篇的AngularJS的教學後,我們對AngularJS的開發應該有了基本的認識,針對HTML文件中我們的操作有:

針對頁面引入應用程式模組

<html ng-app="store">

針對頁面引入控制器

<body ng-controller="StoreController as store">

針對頁面去顯示或隱藏元素

<h1 ng-show="name">Hello, {{ name }} !</h1>

針對大量的資料設定重複的區域

<li ng-repeat="product in store.products">{{ product.name }}</li>
AngularJS Part4 Slide1

接下來針對過濾器來介紹,依下圖所示產品價格的部分,有的是有小數點有的沒有,會造成頁面在資料呈現上的參差不齊。

AngularJS Part4 Slide2

若我們在該表達式(expression)加上一條直線(pipe),在直線後面可以加入一些過濾器,本範例加入的是貨幣格式的過濾器,當加入後價格在頁面上顯示的格式,就會自動加上了$符號和兩位數的小數點。

AngularJS Part4 Slide3

我們也可以在過濾器後面利用冒號再加上一些選項,讓呈現的資料更不同,例如下圖中date格式中是以「月/日/年 @ 時:分AM」這樣的方式顯示,而除了貨幣currency、日期date的過濾器之外,還包含有大小寫轉換的uppercase、lowercase、字數也可以當成資料呈現筆數的limitTo、另外還有可以針對重複性的資料進行排序的orderBy,大概的使用方式可以參考下圖,或是在JS Bin看看馬老師製作的案例。

AngularJS Part4 Slide4

另外關於指示指令部分,在這次的案例上我們加上產品的圖片,圖片的部分有兩種,一個是大圖;另一個是產品的縮圖,也因為有兩種不同的資料,要注意他被加在數列裡面的方式。

AngularJS Part4 Slide5

在頁面上顯示圖片的方式要注意不是用src的屬性去呈現,而是需要用ng-src這個屬性,加上圖片欄位的表達式即可,在JS Bin上面觀賞本案例程式碼。

AngularJS Part4 Slide6

※以上截圖部分為AngularJS官方教學視訊,另有filter指令介紹的專頁和所有filter清單

You may also like...

29,451 Responses

  1. LanceFen表示:

    buy lisinopril canada: lisinopril 250mg – Lisin Express

  2. BrianTom表示:

    buy cheap amoxicillin where can i buy amoxicillin online buy amoxicillin 500mg

  3. Michaelscoob表示:

    zestril 20: Lisin Express – zestril 10 mg

  4. Danieldrymn表示:

    Lisin Express: Lisin Express – lisinopril pills

  5. Richardaudit表示:

    http://clomfastpharm.com/# can you get generic clomid tablets

  6. Michaelscoob表示:

    lisinopril 40 mg tablet: lisinopril medication generic – prinivil price

  7. Richardaudit表示:

    http://amonlinepharm.com/# AmOnlinePharm

  8. Danieldrymn表示:

    generic zithromax 500mg: ZithPharmOnline – zithromax z-pak

  9. Michaelscoob表示:

    ZithPharmOnline: generic zithromax 500mg india – ZithPharmOnline

  10. LanceFen表示:

    where can i get clomid now: Clom Fast Pharm – Clom Fast Pharm

  11. Danieldrymn表示:

    Clom Fast Pharm: can i buy cheap clomid – can you buy generic clomid tablets

  12. Richardaudit表示:

    https://lisinexpress.com/# Lisin Express

  13. alarme Ajax表示:

    Interesting blog! Is your theme custom made or did you download it from somewhere? A theme like yours with a few simple adjustements would really make my blog stand out. Please let me know where you got your design. Kudos

  14. qq88表示:

    Hey there! I’m at work surfing around your blog from my new iphone 4! Just wanted to say I love reading through your blog and look forward to all your posts! Keep up the great work!

  15. BrianTom表示:

    lisinopril 422 Lisin Express lisinopril in india

  16. Michaelscoob表示:

    ZithPharmOnline: where can i get zithromax over the counter – ZithPharmOnline

  17. LanceFen表示:

    Clom Fast Pharm: Clom Fast Pharm – Clom Fast Pharm

  18. Michaelscoob表示:

    can you buy prednisone without a prescription: price of prednisone tablets – prednisone 0.5 mg

  19. Danieldrymn表示:

    zithromax coupon: how to get zithromax over the counter – zithromax for sale online

  20. Richardaudit表示:

    https://lisinexpress.shop/# lisinopril 2 5 mg tablets

  21. Richardaudit表示:

    http://predpharmnet.com/# prednisone 500 mg tablet

  22. Danieldrymn表示:

    amoxicillin cephalexin: amoxicillin online no prescription – AmOnlinePharm

  23. Michaelscoob表示:

    prednisone 50: Pred Pharm Net – generic over the counter prednisone

  24. BrianTom表示:

    Pred Pharm Net prednisone 10mg cost Pred Pharm Net

  25. Danieldrymn表示:

    Clom Fast Pharm: Clom Fast Pharm – Clom Fast Pharm

發佈回覆給「Michaelscoob」的留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。