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,294 Responses

  1. casas表示:

    How long have you been in this field? You seem to know a lot more than I do, I’d love to know your sources!

  2. Alvinimave表示:

    You said it perfectly.
    the best essay writing service how to write a rhetorical essay cheap writing service

  3. Maisiepisn表示:

    free adult dating
    amature dating co
    freeca

  4. arquitectura表示:

    Excellent article!! I am an avid reader of your website:D keep on posting that good content. and I’ll be a regular visitor for a very long time!!

  5. Wendelldub表示:

    Seriously loads of excellent information!
    pharmacy technician classes online free board of pharmacy pharmacie

  6. Alvinimave表示:

    Valuable material. Many thanks!
    colleges that dont require essays how to write good argumentative essays best thesis writing services

  7. Alvinimave表示:

    Thanks, Lots of facts!
    quotes about writing essays how to write a good college application essay essay writing services

  8. 이번에는表示:

    whoah this weblog is great i really like studying your articles. Stay up the great work! You already know, lots of persons are looking round for this information, you can aid them greatly.

  9. pintores表示:

    Hello there I am so delighted I found your weblog, I really found you by mistake, while I was searching on Google for something else, Anyhow I am here now and would just like to say cheers for a remarkable post and a all round exciting blog (I also love the theme/design), I don’t have time to browse it all at the moment but I have book-marked it and also included your RSS feeds, so when I have time I will be back to read a lot more, Please do keep up the superb work.

  10. arrindCen表示:

    It s highly unlikely either of you did anything to cause the miscarriage or could have done anything to prevent it. doxycycline capsule 100mg

  11. Alvinimave表示:

    Incredible quite a lot of terrific data.
    college essay assistance how to write an argumentative essay assignment writing service review

  12. Brucetoush表示:

    You actually mentioned it very well!
    modafinil online pharmacy canadian pharmacy reviews canadian drug

  13. Obersenep表示:

    can i take ibuprofen with doxycycline Cuts that get infected or take long to heal Gentalyn Beta cream.

  14. Obersenep表示:

    doxycycline lyme disease Study discontinuation occurred in 1 case due to excessive vomiting 20C.

  15. Wendelldub表示:

    Valuable forum posts. Thanks.
    online drugstore national pharmacies canadian government approved pharmacies

  16. VABAKAWLBIXfz表示:

    ou acheter du viagra sans ordonnance en france ordonnance viagra amazon viagra

  17. Alvinimave表示:

    Nicely put, Many thanks!
    best online essay writing services https://writingthesistops.com/ wanted freelance writers

  18. Alvinimave表示:

    You explained it well.
    persuasive essay writer writing a synthesis essay college writing services

  19. Obersenep表示:

    The doctor put me on famotidine 40 mg morning and night. what does doxycycline do Only studies which included controls were reviewed.

  20. wewencash表示:

    is doxycycline good for tooth infection The potential side effects would be the same regardless of which form of methotrexate you take.

  21. İzmir Escort表示:

    Great write-up, I am a big believer in placing comments on sites to inform the blog writers know that they’ve added something advantageous to the world wide web!

  22. Alvinimave表示:

    Many thanks, Excellent stuff.
    help writing a college essay how to write a comparative essay help writing personal statement

  23. Brucetoush表示:

    You said it adequately..
    order prescriptions online without doctor pharmacies online canadian pharmacies-247

  24. Genniepisn表示:

    free gay video chat sites
    gay chat roulettye
    black bottom gay chat

  25. Juanitapisn表示:

    dating sites free no registration
    1 dating sites
    meet women at zushi beach

  26. Obersenep表示:

    If I Have Sex With a Yeast Infection, What Should I Keep In Mind. doxycycline for bladder infection

  27. Wendelldub表示:

    This is nicely said. !
    northwest pharmacy canada online discount pharmacy canadian rx pharmacy online

  28. Alvinimave表示:

    Nicely put. Appreciate it.
    writing a narrative essay essaytyper blog writing services

  29. Alvinimave表示:

    Seriously a lot of great advice!
    how to be a good writer essay essay writing service best resume writing services in atlanta ga

  30. Alvinimave表示:

    Thank you! Quite a lot of material!
    write a essay online essay rewriter custom essay writing services reviews

發佈留言

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