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...

3,967 Responses

  1. Columbus表示:

    How To Save Money On Wall Mounted Electric Fires wall mounted
    electric fireplaces (Columbus)

  2. The 10 Scariest Things About Which Is Best For Online Grocery Shopping Which Is Best For Online Grocery Shopping

  3. 7 Things You Never Knew About Mesothelioma Lawsuit mesothelioma Case

  4. Larryzilex表示:

    PBN sites
    We will create a structure of private blog network sites!

    Advantages of our self-owned blog network:

    We perform everything SO THAT Google DOES NOT understand that this is A private blog network!!!

    1- We purchase domain names from distinct registrars

    2- The primary site is hosted on a VPS hosting (Virtual Private Server is rapid hosting)

    3- The remaining sites are on distinct hostings

    4- We attribute a individual Google account to each site with confirmation in Google Search Console.

    5- We develop websites on WP, we don’t employ plugins with assistance from which malware penetrate and through which pages on your websites are generated.

    6- We do not repeat templates and utilize only unique text and pictures

    We refrain from work with website design; the client, if wanted, can then edit the websites to suit his wishes

  5. Larryzilex表示:

    PBN sites
    We will create a web of PBN sites!

    Pros of our privately-owned blog network:

    We perform everything SO THAT Google DOES NOT comprehend that this is A private blog network!!!

    1- We buy domain names from separate registrars

    2- The leading site is hosted on a virtual private server (Virtual Private Server is high-speed hosting)

    3- Other sites are on various hostings

    4- We attribute a separate Google account to each site with verification in Search Console.

    5- We create websites on WP, we don’t utilise plugins with aided by which malware penetrate and through which pages on your websites are generated.

    6- We do not repeat templates and utilise only distinct text and pictures

    We don’t work with website design; the client, if wanted, can then edit the websites to suit his wishes

  6. 5 Common Myths About Wood Burner Fireplace You Should Avoid Wood Burning fireplace

  7. What Is The Reason Why Affordable SEO Packages Uk Are So Helpful
    In COVID-19 Affordable Seo Copywriting

  8. What You Should Be Focusing On Making Improvements SEO Agency Uk seo Agency west london

  9. Fblxux表示:

    glycomet price – buy acarbose 50mg online cheap acarbose 25mg pill

  10. Betty表示:

    Five Killer Quora Answers On All SEO Company In London seo
    company in london (Betty)

  11. See What Retro Espresso Machine Tricks The Celebs Are Using
    retro espresso Machine

  12. Beqouh表示:

    buy generic repaglinide – order jardiance 10mg brand jardiance 10mg

  13. 10 Amazing Graphics About Asbestos asbestos litigation

  14. xisting high비아그라 구매방법ways or rail비아그라 구매방법ways become 비아그라 구매방법the

  15. 5 Killer Quora Answers To Mesothelioma Lawsuit Asbestos Lawsuit

  16. Vcunyr表示:

    order micronase 2.5mg for sale – purchase glucotrol pills forxiga cheap

  17. dic/ vernacu비아그라 구매방법lar name, re비아그라 구매방법ceived from 비아그라 구매방법and

  18. chroma Case表示:

    The No. 1 Question That Anyone Working In CSGO Weapon Case Should Be Able Answer chroma Case

  19. 네이버 아이디 판매 네이버는 다양한 온라인 서비스와 웹사이트를 제공하며, 대한민국을 중심으로 아시아와 기타 지역에서 많은 이용자들에게 서비스를 제공하고 있습니다. 네이버의 주요 서비스 종류는 다음과 같습니다

  20. Gaglhq表示:

    methylprednisolone online pharmacy – buy fml-forte without prescription order generic astelin 10 ml

  21. Etyhxi表示:

    buy clarinex 5mg pills – cost albuterol inhalator albuterol 4mg oral

  22. IR-AMPRI til비아그라 구매e in use in 비아그라 구매the Cath lab비아그라 구매 of

發佈留言

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