AngularJS – 跟著Google玩網頁!

今天馬老師要與大家分享的是一個前端開發的函式庫AngularJS,前面的文章中都有提到,因為近年來行動裝置的普及讓Javascript大為活躍,不過傳統的Javascript在相容性上、操作上都非常的不方便,所以才有了許許多多Javascript的函式庫與框架的誕生,例如:jQuery、KnockoutJS、GSAP、PaperJS…等,每個Javascript的函式庫和框架的大小、作用和目的都不盡相同,有的是為了特效;有的則是為了方便操作,那今天為何要跟大家分享AngularJS呢?因為…它是名牌!

AngularJS 示意圖

為何說AngularJS是名牌呢?因為目前他是由Google來負責維護。初始版本是在2009年誕生的,比jQuery晚了三年,言下之意就會比jQuery好嗎?當然也不能這麼說,jQuery在目前還是一個非常火燙的前端開發函式庫,應該要說他們兩個在使用的架構和目的上會有所不同,這篇文章也來比較一下同樣的案例,在兩種語法上面撰寫的不同。

AngularJS 官方網頁截圖
AngularJS 官方網頁截圖

不過首先我們要知道基本的AngularJS開發方式,今天的案例我們利用JS Bin的線上開發網頁來說明,大家也可以到這個平台上來試著玩看看!如果需要利用AngularJS開發自己的網頁,也可以到AngularJS的官方網頁把JS下載到資料夾之後引用到網頁裡。

1. 首先點選Add library後選擇AngularJS Stable,這樣該平台就會加入AngularJS的函式庫進入頁面。

AngularJS JS Bin Add Library
AngularJS JS Bin Add Library

2. 在標籤中,加入ng-app的屬性,讓整份文件都可以使用AngularJS。

AngularJS JS Bin 增加 HTML 屬性
AngularJS JS Bin 增加 HTML 屬性

3. 接下來就可以在左手邊body標籤內開始輸入一些程式碼來測試,AngularJS在輸出方面有個基本的結構式「{{ }}」,大家輸入以下的程式碼來測試看看結果:  

<!DOCTYPE html>
<html ng-app>
<head>
	<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.2/angular.min.js"></script>
	<meta charset="utf-8">
	<title>JS Bin</title>
</head>
<body>
	<p>{{ '馬老師雲端研究室' }}</p>
	<p>35+62={{ 35+62 }}</p>
	<p>NT{{ 62000 | currency }}</p>
</body>
</html>

可以看到輸出的結果應該是:(在JS Bin上面看AngularJS輸出結果

馬老師雲端研究室

35+62=97

NT$62,000.00

同樣的如果我們要利用jQuery來完成這樣的頁面,程式碼就會變成:(在JS Bin上面看jQuery輸出結果

<!DOCTYPE html>
<html>
<head>
	<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
	<script src="https://cdnjs.cloudflare.com/ajax/libs/numeral.js/1.4.5/numeral.min.js"></script>
	<meta charset="utf-8">
	<title>JS Bin</title>
</head>
<body>
	<p></p>
	<p></p>
	<p></p>
</body>
</html>
<script>
	$("p:eq(0)").text('馬老師雲端研究室')
	$("p:eq(1)").text('35+62=' + (35 + 62))
	$("p:eq(2)").text('NT' + (numeral(62000).format('$ 0,0.00')))
</script>

請注意,為了要完成第三項貨幣型式的呈現,我們還必須去引用這個網站的jQuery Plugin才有辦法比較輕鬆的實現。從上面的案例可以看的出來jQuery是由HTML DOM來抓到對象,再針對對象做操作,而AngularJS不管顯示的效果為何,就是在需要有程式運算的地方出現,所以AngularJS也被稱為符合MVC結構的Javascript函式庫(MVC是一種寫程式的結構,全名是Model View Controller,大家可以上網Google就可以查到很多與MVC相關的資料),但如果你有進入官網,可以看到官網上他的標題是「AngularJS – Superheroic JavaScript MVW Framework」,翻譯成中文大概是「AngularJS是一個符合MV…Whatever什麼什麼隨便啦!的超級函式庫」,可以看出Google的惡搞功夫。

再來示範第二個案例,本案例利用購物行為來製作相關的頁面讓大家參考,程式碼如下:

<!DOCTYPE html>
<html ng-app>
<head>
	<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.2/angular.min.js"></script>
	<meta charset="utf-8">
	<title>JS Bin</title>
</head>
<body ng-init="stock=120;price=325;quantity=1;total=0">
	<p>馬老師雲端研究室 滑鼠墊</p>
	<p>剩餘:<span ng-model="stock">{{ stock-quantity }}</span>個</p>
	<p>單價:<span ng-model="price">{{ price | currency:"NT$":0 }}</span>元</p>
	<p>數量:<input type="number" min="0" max="{{ stock }}" ng-model="quantity"></p>
	<p>總金額:<span ng-model="total">{{ price*quantity | currency:"NT$":0 }}</span></p>
</body>
</html>

輸出結果:(在JS Bin上面看AngularJS輸出結果

AngularJS JS Bin 輸出結果
AngularJS JS Bin 輸出結果

在這個案例裡面有四個項目,分別是商品剩餘數量、單價、數量、總金額,使用者唯一可以改變的只有數量,但頁面中會自動運算剩餘數量和總金額,其中在語法body標籤中,加上了ng-init屬性,代表設定這幾個項目的預設值,stock(剩餘數量)120個、price(單價)325元、quantity(數量)1個,total(總金額)325元。接下來在span內的ng-model就是去綁定該定義項目,{{  }}則是顯示該項目或運算結果,另外貨幣格式的部分,也是用了一些設定讓貨幣在這個案例裡面顯示得更為接近台幣格式,另外還是用HTML5 input標籤的min和max來限制欄位內的值。 而這個案例如果轉換為jQuery的寫法,大概會是下面這樣子:(在JS Bin上面看jQuery輸出結果

<!DOCTYPE html>
<html>
<head>
	<script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
	<script src="http://cdnjs.cloudflare.com/ajax/libs/numeral.js/1.4.5/numeral.min.js"></script>
	<meta charset="utf-8">
	<title>JS Bin</title>
</head>
<body>
	<p>馬老師雲端研究室 滑鼠墊</p>
	<p>剩餘:<span id="stock"></span>個</p>
	<p>單價:<span id="price"></span>元</p>
	<p>數量:<input type="number" min="0" ng-model="quantity" id="quantity"></p>
	<p>總金額:<span id="total"></span>元</p>
</body>
</html>
<script>
	var stock = 120;
	var price = 325;
	var quantity = 1;
	var total = 325;
	$("#stock").text(stock) $("#price").text('NT' + (numeral(price).format('$ 0,0'))) $("#quantity").val(quantity).attr(
		"max", stock) $("#total").text('NT' + (numeral(total).format('$ 0,0'))) $("#quantity").change(function () {
		quantity = $(this).val() newstock = stock - $(this).val() total = price * $(this).val() $("#stock").text(
			newstock) $("#price").text('NT' + (numeral(price).format('$ 0,0'))) $("#total").text('NT' + (
			numeral(total).format('$ 0,0')))
	})
</script>

後記:以上兩個案例示範的是jQuery和AngularJS在撰寫頁面的不同,不過因為這篇文章原本就是要以AngularJS為主,所以挑的案例當然會是AngularJS比較佔優勢的內容,還是跟我常說的一樣,做不同的東西就要用不同的工具,用錯了工具不是做不到,但可能是會事倍功半的!另外文章中的程式碼,都是嵌入遠端的JS檔,所以也可以把整個程式碼複製到你熟悉的網頁開發軟體內,一樣會看到同樣的結果喔!

You may also like...

5,420 Responses

  1. weed pen表示:

    Your style is very unique in comparison to other folks I’ve read stuff from. Many thanks for posting when you have the opportunity, Guess I will just bookmark this site.

  2. Dpeblj表示:

    buy generic prednisone – buy omnacortil 5mg generic buy generic zovirax over the counter

  3. echsa2018.com表示:

    Hi, I do believe this is a great site. I stumbledupon it 😉 I am going to return yet again since i have saved as a favorite it. Money and freedom is the greatest way to change, may you be rich and continue to guide others.

  4. football表示:

    I love reading through an article that will make men and women think. Also, thank you for permitting me to comment.

  5. Can I simply say what a relief to uncover an individual who truly understands what they’re discussing on the net. You definitely realize how to bring a problem to light and make it important. More and more people really need to check this out and understand this side of your story. I was surprised that you aren’t more popular given that you certainly have the gift.

  6. This is fantastic! Packed with helpful insights and extremely clear. Thank you for offering this.

  7. Howdy! This blog post could not be written much better! Looking through this post reminds me of my previous roommate! He constantly kept preaching about this. I will forward this article to him. Fairly certain he’ll have a great read. Thank you for sharing!

  8. Hi, I do believe this is a great site. I stumbledupon it 😉 I am going to revisit once again since i have book marked it. Money and freedom is the greatest way to change, may you be rich and continue to help others.

  9. В народной медицине существует множество методов лечения абсцесса народными средствами, которые включают использование различных трав и настоев. Эти методы помогают уменьшить воспаление, снизить болевые ощущения и ускорить процесс заживления. Такие натуральные средства, как каланхоэ, алоэ и зверобой, обладают антисептическими и ранозаживляющими свойствами, что делает их эффективными в борьбе с абсцессами.

  10. Josephsamma表示:


    Временная регистрация в Санкт-Петербурге: Быстро и Легально!
    Ищете, где оформить временную регистрацию в СПБ?
    Мы гарантируем быстрое и легальное оформление без очередей и лишних документов.
    Ваше спокойствие – наша забота!
    Минимум усилий • Максимум удобства • Полная легальность
    Свяжитесь с нами прямо сейчас!
    Временная регистрация в СПБ

  11. ArnfPaish表示:

    What we actually know is about how to relieve symptoms.
    Compare the price of can you cut tadalafil in half at a fraction of the normal cost
    The message from this study is that smoking at a very young age may be especially likely to cause lung damage that lasts a lifetime.

  12. Everyone loves it when individuals get together and share views. Great blog, continue the good work!

  13. DFW Roofers表示:

    That is a really good tip especially to those new to the blogosphere. Short but very accurate information… Thank you for sharing this one. A must read post!

  14. Stanleyerurl表示:


    Временная регистрация в Санкт-Петербурге: Быстро и Легально!
    Ищете, где оформить временную регистрацию в СПб?
    Мы гарантируем быстрое и легальное оформление без очередей и лишних документов.
    Ваше спокойствие – наша забота!
    Минимум усилий • Максимум удобства • Полная легальность
    Свяжитесь с нами прямо сейчас!
    Временная регистрация в СПб

  15. Chaga mushroom dinner might have been taught a lot of globally by means of Euro contributor Alexandr Solzhenitsyn michael’s narrative ‘Cancer Ward’ exactly where the large person could alleviated linked with types of cancer among help from this specific coffee. Chaga Mushroom

  16. Oh my goodness! Incredible article dude! Thank you, However I am experiencing issues with your RSS. I don’t understand why I am unable to subscribe to it. Is there anybody else getting similar RSS issues? Anyone who knows the answer will you kindly respond? Thanks!

  17. Wiqnpp表示:

    isotretinoin order – avlosulfon without prescription purchase deltasone generic

  18. Timothystoft表示:

    indianpharmacy com: buy medicines online in india – mail order pharmacy india

  19. Timothystoft表示:

    rate canadian pharmacies: canadian pharmacy antibiotics – canadian 24 hour pharmacy

  20. Pretty! This was a really wonderful article. Thank you for supplying this info.

  21. Wonderful entry. It offered a lot of helpful details. I value the time you put in to compose this content.

  22. 789win表示:

    {Tôi đã khá hài lòng khám phá trang web này. Tôi muốn cảm ơn bạn {vì đã|dành thời gian cho|chỉ vì điều này|vì điều này|cho bài đọc tuyệt vời này!! Tôi chắc chắn thực sự thích từng một phần nó và tôi cũng đã đánh dấu trang để xem thông tin mới trên blog của bạn.|Tôi có thể chỉ nói rằng thật nhẹ nhõm để tìm thấy một người mà thực sự hiểu họ là gì thảo luận trên internet. Bạn thực sự nhận ra cách đưa một vấn đề ra ánh sáng và làm cho nó trở nên quan trọng. Nhiều người hơn cần đọc điều này và hiểu khía cạnh này câu chuyện của bạn. Tôi đã ngạc nhiên bạn không nổi tiếng hơn cho rằng bạn chắc chắn sở hữu món quà.|Tốt bài viết. Tôi chắc chắn đánh giá cao trang web này. Tiếp tục viết!|Thật khó tìm những người có học thức về điều này, tuy nhiên, bạn nghe có vẻ bạn biết mình đang nói gì! Cảm ơn|Bạn nên tham gia một cuộc thi dành cho một trang web trên mạng tuyệt vời nhất. Tôi sẽ khuyến nghị trang web này!|Một động lực đáng giá bình luận. Tôi tin rằng bạn nên xuất bản thêm về chủ đề này, nó có thể không là một điều cấm kỵ vấn đề nhưng nói chung mọi người không nói về những chủ đề như vậy. Đến phần tiếp theo! Chúc mừng!|Xin chào! Tôi chỉ muốn cho bạn một rất cho thông tin xuất sắc bạn có ở đây trên bài đăng này. Tôi sẽ là trở lại trang web của bạn để biết thêm thông tin sớm nhất.|Sau khi tôi ban đầu bình luận tôi có vẻ như đã nhấp vào hộp kiểm -Thông báo cho tôi khi có bình luận mới- và bây giờ bất cứ khi nào có bình luận được thêm vào tôi nhận được 4 email có cùng nội dung. Có một phương tiện bạn có thể xóa tôi khỏi dịch vụ đó không? Cảm ơn rất nhiều.|Lần sau Tôi đọc một blog, Hy vọng rằng nó sẽ không làm tôi thất vọng nhiều như bài này. Rốt cuộc, Vâng, đó là sự lựa chọn của tôi để đọc, tuy nhiên tôi thực sự tin bạn sẽ có điều gì đó hữu ích để nói về. Tất cả những gì tôi nghe được là một loạt tiếng rên rỉ về điều gì đó mà bạn có thể sửa nếu bạn không quá bận tìm kiếm sự chú ý.|Đúng với bài viết này, tôi thành thật nghĩ trang web này cần nhiều hơn nữa sự chú ý.

  23. Stanleyerurl表示:


    Временная регистрация в СПб: Быстро и Легально!
    Ищете, где оформить временную регистрацию в Санкт-Петербурге?
    Мы гарантируем быстрое и легальное оформление без очередей и лишних документов.
    Ваше спокойствие – наша забота!
    Минимум усилий • Максимум удобства • Полная легальность
    Свяжитесь с нами прямо сейчас!
    Временная регистрация

  24. Timothystoft表示:

    pharmacies in mexico that ship to usa: reputable mexican pharmacies online – mexican online pharmacies prescription drugs

  25. sky88表示:

    {Tôi đã hạnh phúc hơn cả vui khám phá trang web này. Tôi muốn cảm ơn bạn {vì đã|dành thời gian cho|chỉ vì điều này|vì điều này|cho bài đọc tuyệt vời này!! Tôi chắc chắn đánh giá cao từng của nó và tôi đã đánh dấu trang để xem điều mới trên trang web của bạn.|Tôi có thể chỉ nói rằng thật nhẹ nhõm để khám phá một người thực sự hiểu họ là gì đang nói về trực tuyến. Bạn chắc chắn nhận ra cách đưa một rắc rối ra ánh sáng và làm cho nó trở nên quan trọng. Nhiều người hơn nên xem điều này và hiểu khía cạnh này của. Tôi không thể tin bạn không nổi tiếng hơn vì bạn chắc chắn sở hữu món quà.|Rất hay bài viết trên blog. Tôi hoàn toàn đánh giá cao trang web này. Tiếp tục làm tốt!|Thật khó tìm những người có kinh nghiệm cho điều này, nhưng bạn nghe có vẻ bạn biết mình đang nói gì! Cảm ơn|Bạn nên tham gia một cuộc thi dành cho một trang web trực tuyến tuyệt vời nhất. Tôi sẽ Rất khuyến nghị trang web này!|Một động lực chắc chắn đáng giá bình luận. Tôi tin rằng bạn nên xuất bản thêm về chủ đề này, nó có thể không là một điều cấm kỵ vấn đề nhưng nói chung mọi người không nói về vấn đề những điều này. Đến phần tiếp theo! Chúc mọi điều tốt đẹp nhất.|Chào bạn! Tôi chỉ muốn đề nghị rất cho thông tin tuyệt vời bạn có ngay tại đây trên bài đăng này. Tôi đang quay lại trang web của bạn để biết thêm thông tin sớm nhất.|Sau khi tôi ban đầu bình luận tôi có vẻ như đã nhấp hộp kiểm -Thông báo cho tôi khi có bình luận mới- và từ bây giờ bất cứ khi nào có bình luận được thêm vào tôi nhận được bốn email có cùng nội dung. Phải có một phương tiện bạn có thể xóa tôi khỏi dịch vụ đó không? Kudos.|Lần sau Tôi đọc một blog, Tôi hy vọng rằng nó không thất bại nhiều như bài này. Ý tôi là, Tôi biết điều đó là sự lựa chọn của tôi để đọc hết, nhưng tôi thực sự nghĩ bạn sẽ có điều gì đó hữu ích để nói. Tất cả những gì tôi nghe được là một loạt khóc lóc về điều gì đó mà bạn có thể sửa nếu bạn không quá bận tìm kiếm sự chú ý.|Đúng với bài viết này, tôi hoàn toàn nghĩ trang web này cần nhiều hơn nữa sự chú ý.

  26. Steveninela表示:


    Новые методы лечения болезни Паркинсона в клинике Neuro Implant Clinic.
    Акупунктура уха – новый метод лечения болезни Паркинсона, Альцгеймера, Рассеянного Склероза.
    Выездное лечение в разные Страны.
    Отзывы нашего метода на официальном сайте Neuro Implant Clinic.

  27. I was just looking for this information for some time. After six hours of continuous Googleing, finally I got it in your website. I wonder what’s the lack of Google strategy that do not rank this type of informative sites in top of the list. Generally the top sites are full of garbage.

  28. Timothystoft表示:

    indian pharmacy: indian pharmacy – reputable indian online pharmacy

  29. ArnvPaish表示:

    It never felt like it ‘aborted completely’ and the symptoms never really eased.
    Excellent treatment is achievable when you how to use tadalafil from them.
    Coccidioidomycosis, otherwise known as Valley Fever and sometimes referred to as “California disease” or “Desert rheumatism” , is an infectious disease caused by a fungal organism called Coccidioides Immitis.

  30. ArnfPaish表示:

    Rebecca Gardner I was wondering if someone could help me out??
    Fastest delivery and lowest prices for tadalafil controlled substance Learn more about it!
    For increased protection, use a high-efficiency HEPA air cleaner in this bedroom.

發佈留言

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