跳到主要內容

[分享] Angular concept & event binding



以前在寫前端的方式,會採取 html, css, js 分離的方式。這次活動邀請 Gias 來彰化師大與同學分享 Angular.js, 也比較了解 Angular 的概念,話說,把 HTML 當做一種 interface 的概念,其實還蠻不一樣的,就說法層面上會比較能夠說得過去,不過比對以前的寫法又覺得有點開倒車。

這邊是想要提出一件事情,這邊強調要快速開發,我們以一個 list link 為例子

     <ul>
          <li><a href="#">click</a></li>
          <li><a href="#">click</a></li>
          <li><a href="#">click</a></li>
          <li><a href="#">click</a></li>
     </ul>

如果加入 angular 的作法就會比較像底下的方式

     <ul>
          <li><a href="#" ng-click="click()">click</a></li>
          <li><a href="#" ng-click="click()">click</a></li>
          <li><a href="#" ng-click="click()">click</a></li>
          <li><a href="#" ng-click="click()">click</a></li>
     </ul>

說服

當然這個模式並不是不好,只是對於一開始接觸真的會覺得是在開倒車,因為以往我們一直強調大家不要在 HTML 加入 js 程式碼,所以不建議使用 inline function, 可是現在卻發生這樣的寫法。

在 Angular 裡面,強調的是 HTML is an interface. 所以他就是一個介面,並不是文字結構,既然 HTML 是用來呈現,給予使用者點擊,接觸,使用,那把 function 加入在 HTML 裡面,似乎又變成合情合理。

效能

當然接下來有另外一個問題,就是 ng-click 這樣的方式,如果有寫過前端的朋友應該就可以發現,另外一個隱藏的問題就是 performance issue, 在 Angular 裡面,他已經做好 compiler 的動作,因此作者認為,人眼對於 50ms 以下的變動時間,是不會有真正感覺的。在 Angular 裡面, performance 的差異會是在 2000 個以上物件之後才會發生問題,所以只要你的物件可以確保不在 2000 個以上,基本上不會出現任何問題。

如果超過 2000???

如果這個事情發生,作者希望你重新思考 binding event 的方法,或者你的使用方法開始有錯誤的方向。意味著千錯萬錯,都是使用者的錯。

個人觀點

以目前最新的瀏覽器來說,加上目前電腦的效率,基本上這樣的方式是非常簡單就可以達到的目的,如 Gias 所說,Angular 是想要把瀏覽器的使用率逼到極致。不用再去管那些雞毛蒜皮的小事情,只要照著 angular 的作法執行就對了,That is angular way. 

當然對於開倒車這件事情,一開始還是不太能認同,但是經過解說之後,了解他背後希望達到的事情,就會有另外一種體認,這跟程式無關,比較是精神和信仰上面的作法,就像是到寺廟裡面拿香拜神,跟著基督教吃飯前要禱告一樣,就是一種『精神信仰引導行為模式』,這種事情沒有絕對,也沒有最佳的解決方法,有的時候,程式開發人員保持一種開放的心態,保持著謙和的態度,才能夠集大成,因為我也正在持續觀看學習中。

導讀資料


  • http://stackoverflow.com/questions/9682092/databinding-in-angularjs/9693933#9693933





http://stackoverflow.com/questions/9682092/databinding-in-angularjs/9693933#9693933

留言

這個網誌中的熱門文章

面試者如何挑戰大工程師時代來臨?

面試者如何挑戰大工程師時代來臨? 全世界都在倡導轉職成為工程師,似乎轉職成為工程師就成為職場的救贖,真的是如此嗎?讓老衲來杠給各位聽。 最近有位好久不見的小朋友,是 2000 年出生的小蔡,對於即將面臨到面對職場的挑戰開始關心起技術,他開始尋找比較適合自己的領域,同時也開始在思考到底為了接下來的就職小蔡該如何準備。 詢問我說是不是可以考慮軟體開發工程師這條路線 對於他的詢問,反而引起我的注意, 這讓我開始思考並映射於最近招募的經驗,軟體開發此領域是不是對於每個人都是可以擔任的職啀,這邊分享一些自己的看法希望對各位有所幫助。 全民工程師這件事情 在全球景氣低迷的狀況下,的確特別在這一年大家會很有感覺萬物齊漲,薪水不漲,薪資就是一直停滯不前。 很多時候,在不同的領域中,會發現整個薪資就算是擔任了管理職務主管你也會面臨到薪資的強大屏障在自己面前。 這個時候, 軟體工程師年薪百萬口號 似乎就成了一種救贖。 好像成為了工程師就可以達到年薪百萬,在家輕鬆工作,不用打卡也不用受到風吹雨淋,隨時想工作就可以工作,每個月又有固定薪水入帳,感受到類財富自由,人生的美好。 如果能夠爭取到跨國公司的職位,這份薪水有可能還可以上看每個月十多萬以上,甚至是往上也是極度有可能的事情,人生美好層次又再度提高了起來。 但這件事情是真的每個人都可以達到嗎? 還是這就是另外一種性存者偏差呢? 亦或者這些人其實是金字塔頂端的小眾? 每份履歷都像是同一種履歷 最近在最近幾年在面試工程師的時候特別會看到許多轉職者,一開始履歷裡面看到相關的作品一開始會覺得十分的驚艷, Wow, 現在的新手就可以做到如此精美的畫面,這些畫面是我當初用 Bootstrap 也做不出來的東西,許多的互動體驗好的一個不行,做出來的頁面配色和對齊也是極致。 但是隨著時間推移,多看了幾封履歷之後,就會發現在各大技術養成學院出來的學生履歷成果內容如出一轍,在面試的過程中也會詢問許多關於框架的底層概念,和比較技術觀念的時候,甚至是許多框架的核心概念,就很容易露出馬腳。 很多面試者會 一問三不知 ,透過許多引導,但殘酷的是連關鍵字是什麼都也無法推敲出來,更不用說在小組裡面到底怎麼樣合作,許多不同線上產品的比較,使用者流程,使用者後面的互動邏輯等,幾乎是風吹一片倒,只能

jQuery, animate function with css exlapenation.

Today, I want to use jQuery making a animation for webpage, First I check animate fuction on ref book. I clearly know how use it, there are two main function for animate. 1. $().animate({ "style1":"value1" , "style2":"value2" }, Time); Time: it can be three type, String => "slow", "fast", "normal". Integer=>10000 2. $().stop(); it can immedaitely stop animation. Let's do some experieces, I bulit a simple page. You can hover UP and DOWN for a article sliding UP or DOWN. Les't do it. HTML CODE: <div id="all"> <div id="up">往上</div> <div id="showTab"> <div id="data"> About This script is intended for forms where the user needs to upload an image to a Web site. The image is displayed on the page for previewing before uploading. The display will be resized if needed so as not to break the page layout. Valid file types are set in the scri

初探 LangChain:語言模型應用程式開發的強大框架

LangChain 是一個強大的框架,致力於幫助開發人員利用語言模型構建端到端的應用程式。它提供了一整套工具、組件和接口,大大簡化了創建由大型語言模型(LLM)和聊天模型支持的應用程式的過程。LangChain 可以輕鬆地管理與語言模型的互動,將多個組件連接在一起,並集成額外的資源,例如 API 和資料庫。 LangChain https://python.langchain.com/en/latest/index.html 不說廢話,直接開始試著安裝, pip install langchain pip install openai export OPENAI_API_KEY="..." 以下是一些 LangChain 的簡單程式碼: import os os.environ["OPENAI_API_KEY"] = "..." from langchain.llms import OpenAI from langchain import OpenAI, ConversationChain from langchain.agents import initialize_agent from langchain.agents import load_tools from langchain.chains import LLMChain from langchain.prompts import PromptTemplate prompt = PromptTemplate( input_variables=["product"], template="What is a good name for a company that makes {product}?", ) print(prompt.format(product="colorful socks")) # What is a good name for a company that makes colorful socks? 在 LangChain 中,開發人員可以使用 LLM、Chat Model、Agents、Chains、Memory