This post will cover a few major topics in Angular including factories, promises, and injection. In Angular, when you are writing your actual app you will most likely have some kind of service or rest endpoint that you are hitting. Angular has a lot of features that help you write your code in a cleaner and more maintainable way, or allow you to use your existing services and just leverage the features you want in an Angular app.
When defining a service in Angular, there are two different modules provided for you. They are the factory module and the service module. They are fairly similar, but in the end I chose to use the factory module because 99% of the examples on the Angular site are done using it instead of the service module. For some more info on the differences on these two modules you can check out this SO post.
Thursday, August 22, 2013
Tuesday, August 13, 2013
Getting Started with Angular Part 2. Filters.
The next topic to discuss in Angular is Filters. Filters typically are used to format
expressions in bindings in your template.
Filters can transform data to a new type, be chained, and take in
optional arguments.
Building on the previous example, I added a new field to our
models called Orbit. This represents the
orbit of the object in days. In our view
I added a new line to display the orbit on the page just like the other read-only
properties before:
<div>{{object.Orbit}}</div>
Wednesday, August 7, 2013
Getting Started With Angular
Obviously the first thing you need to do to get started is to download Angular.js from http://code.angularjs.org/. Let’s create a simple page with a script and
index.html file. The first thing we are
going to do is define our UI. What we
are going to display is a parent entity (Sun) and a list of all of the orbiting
bodies (planets and pluto).
Monday, August 5, 2013
Angular JS Tutorial Intro
A couple weeks ago at Sonoma, we had a labs day where we could break into groups and work on whatever we wanted to. My main goal for the labs was to work with something I hadn't worked with before. The few areas I am currently interested in growing in are working with mobile (I don't have a mac so this is limited to android), JS frameworks, and open-sourced web frameworks (Rails/Django). I joined up with a group that was going to work on keeping track of internal training.
My main part had to do with displaying child records in an iframe on the parent training record in our Microsoft CRM environment. Unless you wanted to create your own app from scratch and link the URL to that page the only way to have a custom UI hosted inside the CRM app is to have a Silverlight page or HTML/JS page that is loaded into CRM.
I decided to write my part in angular so I would be working with a new framework. I thought that it would be a breeze to learn it since I already had knockout experience, but it ended up taking me way longer than I expected. I was able to get into the hang of it and created a directive using a custom html tag. One thing I will say for Knockout is their tutorials and SDK are really well flushed out. I found Angular's confusing and lack of definition irritating. You can see one of the early versions of the project on my Github page here.
My main part had to do with displaying child records in an iframe on the parent training record in our Microsoft CRM environment. Unless you wanted to create your own app from scratch and link the URL to that page the only way to have a custom UI hosted inside the CRM app is to have a Silverlight page or HTML/JS page that is loaded into CRM.
I decided to write my part in angular so I would be working with a new framework. I thought that it would be a breeze to learn it since I already had knockout experience, but it ended up taking me way longer than I expected. I was able to get into the hang of it and created a directive using a custom html tag. One thing I will say for Knockout is their tutorials and SDK are really well flushed out. I found Angular's confusing and lack of definition irritating. You can see one of the early versions of the project on my Github page here.
Subscribe to:
Posts (Atom)