AngularJS – Controller 介紹篇
繼續AngularJS的介紹,接下來我們看看controller的應用,以商品介紹的頁面為例,來看看這些資料要如何呈現在頁面上,想要呈現的資料有產品名稱、價格以及描述。
為了方便文章閱讀,本篇將application翻譯成應用程式;controller翻譯成控制器
控制器負責定義函數和值來決定整個應用程式的行為,同樣我們把Javascript和HTML分開來開發,在app.js內定義應用程式名稱和控制器的名稱、函數與值,在這次的案例中也提到利用(function(){})()包裝整個javascript是一種好習慣,有關於函式的基本觀念,大家可以閱讀一下這篇文章,介紹的還蠻詳細的!包裝部分的概念可參考其中介紹的立即函示(IIFE – Immediately Invoked Function Expression)。
定義好之後可以開始定義該控制器內的值,其中this.product=gem的意思是指未來在輸出時可以利用product.name去取得Dodecahedron;product.price去取得2.95…等等。
接下來就是把這些值顯示在網頁上,首先可以在div標籤內加上ng-controller=”StoreController as store”的屬性,其中ng-controller是去指定StoreController為該div內的控制器名稱;store是別名(類似綽號)未來呼叫store時就是在呼叫StoreController這個控制器。
在HTML標籤內開始輸出該控制器內的值,分別是:store.product.name、store.product.price、store.product.description三個項目,而在頁面上就會看到這三個值被顯示出來了。
需要注意的是,如果我們把輸出值部分的程式碼放在div外側的話,會沒有辦法順利的顯示值,因為我們的控制器是指定於div標籤內,離開了div標籤就無法取得該控制器了。
本篇的教學就到這邊,大家也可以透過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官方教學視訊,另有控制器指令介紹的專頁。
https://social111.s3.amazonaws.com/upload/files/2022/05/wak8X15Tp3rCVXvqqe1T_17_0fbc0895f34f0f96a40dac4f3bae6825_file.pdf
341c3170be karorea
giucli 341c3170be http://www.visitmenowonline.com/upload/files/2022/05/9mHC8cf4ZsSrVm1AbebO_17_5afed0a623e3d152dc80c1e424b76b10_file.pdf
tadthal 341c3170be https://cse.google.ae/url?sa=i&url=https://www.adultzoo.club/upload/files/2022/05/XiydCFrrjQkAtDdgX6Oy_17_0fbc005bfffb89af406d1f12a8dd14af_file.pdf
provigil us buy provigil generic
inijani 341c3170be http://bittersweet.raindrop.jp/etc/goto.php?url=https://chatbook.pk/upload/files/2022/05/cdwp8P7tQrMSFJT4Mil8_17_92c1ae9a4f19cca0327207ba3b4513f5_file.pdf
patbet 341c3170be https://avicii.app/upload/files/2022/05/beo17q6kOJxnHaQiwaV7_17_ff990ab840a87d72d733973c9ab2e7c7_file.pdf
provigil 100mg ca provigil pills
quaevan 341c3170be https://www.google.fi/url?q=https://friendship.money/upload/files/2022/05/eG4jwCLAj46NPOIHCnmM_17_de8699cea92724018ed79df2239e03f4_file.pdf
laveulym 341c3170be https://www.uasean.com/redirect.php?url=https://americap2.nyc3.digitaloceanspaces.com/upload/files/2022/05/7kbK5hlblPTvy3KUkvKq_17_ef94727903fbfc0cbd6db2de0560706c_file.pdf
tadalafil 20 mg buy online cialis coupon cialis pharmacy
gysegen 341c3170be https://www.google.ie/url?sa=i&url=https://www.sertani.com/upload/files/2022/05/GpOQNq3ThqrN8ln7tBhi_17_78addc01623cad37cdfee75f04948668_file.pdf
jaravili 341c3170be https://maps.google.com.vc/url?sa=t&url=https://popstay.info/upload/files/2022/05/NaQ2AyLd2BnAsLOknnzO_17_c8381ef69aca5195ddf82919455052a8_file.pdf
provigil cost
buy modafinil 200mg
fynmelv 807794c184 http://www.martincreed.com/?URL=https://www.imaet.com/profile/Compass-Crack-Serial-Key-Updated-2022/profile
kriswyl 807794c184 https://toolbarqueries.google.co.vi/url?q=https://www.crestridgealumnae.com/profile/Paragon-Drive-Copy-Professional-Crack-License-Key-Download-MacWin-March2022/profile
natavano 807794c184 https://www.vorsheershop.com/profile/femininesakunah/profile
elroraf 807794c184 http://image.google.bf/url?q=https://www.thecookieworkshop.sg/profile/ackerlygilroygilroy/profile
kaesbaku 807794c184 http://deancharlesassoc.com/__media__/js/netsoltrademark.php?d=https://www.internationalhealthcollective.org/profile/SJphone-Crack-License-Keygen-Free-Download-3264bit/profile
whelat 807794c184 http://ablebright.com/__media__/js/netsoltrademark.php?d=https://www.mjcullinane.com/profile/percieflechapercie/profile
order modafinil 100mg pills
warfab 807794c184 http://johncoulter.biz/__media__/js/netsoltrademark.php?d=https://www.rubert-international.com/profile/eigelseigelswalhalla/profile
warfab 807794c184 http://johncoulter.biz/__media__/js/netsoltrademark.php?d=https://www.rubert-international.com/profile/eigelseigelswalhalla/profile
erythromycin topical solution erythromycin base
balhan 807794c184 http://nyveincenter.com/__media__/js/netsoltrademark.php?d=https://www.csi3.org/profile/Quick-All-To-PDF-Crack-Free-Updated-2022/profile
rocbre 807794c184 http://girlsoftball.com/__media__/js/netsoltrademark.php?d=https://www.cwfitness20.com/profile/izadorewatcherzaverey/profile
alfovan 807794c184 https://toolbarqueries.google.dk/url?q=https://www.portofinoatl.com/profile/Antamedia-POS-Crack-With-License-Code-3264bit/profile
shaisal 807794c184 http://pluto.no/frame.tmpl?url=https://www.crowevalleycamp.com/profile/Ezdiag-Crack-Serial-Key-Free-Latest2022/profile
top rated canadian pharmacies online canadian pharmacies not requiring prescription buying from canadian online pharmacies
corngear 7bd55e62be https://www.austwestoutdoors.com.au/profile/chrisandersabdea/profile