AngularJS – Controller 介紹篇

繼續AngularJS的介紹,接下來我們看看controller的應用,以商品介紹的頁面為例,來看看這些資料要如何呈現在頁面上,想要呈現的資料有產品名稱、價格以及描述。

為了方便文章閱讀,本篇將application翻譯成應用程式;controller翻譯成控制器

AngularJS Part2 Slide1

控制器負責定義函數和值來決定整個應用程式的行為,同樣我們把Javascript和HTML分開來開發,在app.js內定義應用程式名稱和控制器的名稱、函數與值,在這次的案例中也提到利用(function(){})()包裝整個javascript是一種好習慣,有關於函式的基本觀念,大家可以閱讀一下這篇文章,介紹的還蠻詳細的!包裝部分的概念可參考其中介紹的立即函示(IIFE – Immediately Invoked Function Expression)。

AngularJS Part2 Slide2

定義好之後可以開始定義該控制器內的值,其中this.product=gem的意思是指未來在輸出時可以利用product.name去取得Dodecahedron;product.price去取得2.95…等等。

AngularJS Part2 Slide3

接下來就是把這些值顯示在網頁上,首先可以在div標籤內加上ng-controller=”StoreController as store”的屬性,其中ng-controller是去指定StoreController為該div內的控制器名稱;store是別名(類似綽號)未來呼叫store時就是在呼叫StoreController這個控制器。

AngularJS Part2 Slide5

在HTML標籤內開始輸出該控制器內的值,分別是:store.product.name、store.product.price、store.product.description三個項目,而在頁面上就會看到這三個值被顯示出來了。

AngularJS Part2 Slide6

需要注意的是,如果我們把輸出值部分的程式碼放在div外側的話,會沒有辦法順利的顯示值,因為我們的控制器是指定於div標籤內,離開了div標籤就無法取得該控制器了。

AngularJS Part2 Slide7

本篇的教學就到這邊,大家也可以透過JS Bin來測試或閱讀本次案例的程式碼。

<!DOCTYPE html>
<html ng-app="store">
<head>
<meta name="description" content="controllerExample">
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.2/angular.min.js"></script>
  <meta charset="utf-8">
  <title>controllerExample</title>
</head>
<body>
  
  <div ng-controller="StoreController as store">
    <h1>{{ store.product.name }}</h1>
    <h2>{{ store.product.price }}</h2>
    <p>{{ store.product.description }}</p>
  </div>
  
</body>
</html>
(function(){
  var app = angular.module('store',[]);
  
  app.controller('StoreController',function(){
    this.product = item;
  });
  
  var item = {
    name:"馬老師雲端研究室 滑鼠墊",
    price:"350",
    description:"有些人認為滑鼠墊就只是種簡單的產品。無非是將滑鼠放於上方並將之滑來拖去。 “表面”上來說確實如此(一語雙關)。但實際上,製造能帶來卓越遊戲體驗的滑鼠墊卻需要結合眾多科學、技術和工藝。身為遊戲滑鼠技術的世界領先者,對如何使滑鼠感測器高效運作我們獨樹一幟。運用專門知識來製造適合的滑鼠墊表面,讓滑鼠感測器得以作出高效而精確的反應。",    
  };
  
})();

※以上截圖部分為AngularJS官方教學視訊,另有控制器指令介紹的專頁

You may also like...

9,285 Responses

  1. Brucetoush表示:

    Cheers. Quite a lot of advice.
    online medicine tablets shopping aarp recommended canadian pharmacies cheap prescription drugs

  2. Wendelldub表示:

    You stated this really well.
    drugstore online shopping cialis online pharmacy canada prescriptions drugs

  3. Alvinimave表示:

    Seriously tons of awesome knowledge!
    essay custom https://freshapps.space/ essay writing service review

  4. Alvinimave表示:

    Many thanks. Ample postings.
    stephen king essay on writing https://flowleadsua.com/ custom essay writing service reviews

  5. Are grateful for this blog post, it’s tough to find good information and facts on the internet

  6. 두팔로우表示:

    WoW decent article. Can I hire you to guest write for my blog? If so send me an email!

  7. Mavispisn表示:

    dating gratis
    dating for free
    best date sites

  8. Alvinimave表示:

    Amazing knowledge. Cheers!
    analysis essay help https://writingthesistops.com/ pay someone to write my assignment

  9. Brucetoush表示:

    Seriously loads of awesome info.
    prescription drugs online without online pet pharmacy northwest pharmaceuticals canada

  10. Alvinimave表示:

    Kudos. Plenty of forum posts!
    cuny college essay https://ouressays.com/ research and writing services

  11. Alvinimave表示:

    Terrific postings. Regards.
    how to write biography essay https://homeworkcourseworkhelps.com/ help writing a book

  12. Wendelldub表示:

    Incredible lots of fantastic tips.
    online pharmacy without scripts canadian pharma companies walgreens online pharmacy

  13. Deeynpisn表示:

    gay video chat surry county nc
    best gay chat
    gay black man chat

  14. 노팔로우表示:

    nicee content keep writing

  15. SABAKAWLBIXma表示:

    buy cenforce 100mg generic order sildenafil pill buy sildenafil 100mg online cheap

  16. Alvinimave表示:

    Reliable material. Thanks!
    i need someone to write my essay essay typer proposal writing services

  17. Brucetoush表示:

    Truly a lot of useful data.
    canadian pharmacy canada pharma limited llc canadian pharmacies online

  18. Alvinimave表示:

    Many thanks, I like this.
    cheap essay writing service https://freshappshere.com/ article writing service review

  19. Alvinimave表示:

    Superb content, Kudos!
    how to write college essay https://essaywriting4you.com/ online custom writing services

  20. Wendelldub表示:

    Seriously all kinds of excellent info.
    prescription discount canada pharmacy online orders online drugstore pharmacy

  21. spervenef表示:

    Dogan K, Ekin M, HelvacioДџlu Г‡, YaЕџar L. tamoxifen vs aromatase inhibitor

  22. sbobet表示:

    Very often I go to see this blog. It very much is pleasant to me. Thanks the author

  23. construccion表示:

    What’s Happening i’m new to this, I stumbled upon this I’ve found It positively useful and it has aided me out loads. I hope to contribute & help other users like its aided me. Great job.

  24. calle aragon表示:

    Wow, amazing blog layout! How long have you been blogging for? you made blogging look easy. The overall look of your site is great, as well as the content!

  25. spervenef表示:

    As the developing fetus reaches a certain weight, the weakened cervix cannot support the fetus and sometimes results in miscarriage. letrozole vs tamoxifen

  26. Alvinimave表示:

    Thanks. Plenty of data.
    write my essay for me cheap write my essays need a ghostwriter

  27. Brucetoush表示:

    Regards! I like it!
    drug price best online canadian pharcharmy pharmacies in canada

  28. Alvinimave表示:

    You actually explained that effectively!
    college admission essay editing services writing my essay resume writing service

  29. Alvinimave表示:

    Thanks a lot. I appreciate this!
    how to write a short story essay narrative essays for college help me write a report

  30. Wendelldub表示:

    You said it perfectly..
    drugs online prescription drugs without prior prescription the canadian pharmacy

發佈留言

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