Skip to main content

AngularJS - Tables

Table data is normally repeatable by nature. ng-repeat directive can be used to draw table easily.  Following example states the use of ng-repeat directive to draw a table. <table> <tr> <th> Name </th> <th> Marks </th> </tr> <tr ng-repeat = "subject in student.subjects" > <td> {{ subject.name }} </td> <td> {{ subject.marks }} </td> </tr> </table> Table can be styled using CSS Styling. <style> table , th , td { border : 1px solid grey ; border - collapse : collapse ; padding : 5px ; } table tr : nth - child ( odd ) { background - color : #f2f2f2; } table tr : nth - child ( even ) { background - color : #ffffff; } </style> Example Following example will showcase all the above mentioned directive. <html> <head> <...

Angular 2 Create And Inject Service

index.html


<!DOCTYPE html>
<html>

<head>
<title>Angular 2 Create And Inject Service With Examples</title>
<link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
<link rel="stylesheet" href="style.css" />
<script src="https://code.angularjs.org/2.0.0-beta.17/angular2-polyfills.js"></script>
<script src="https://code.angularjs.org/tools/system.js"></script>
<script src="https://code.angularjs.org/tools/typescript.js"></script>
<script src="config.js"></script>
<script>
System.import('app')
.catch(console.error.bind(console));
</script>
</head>

<body>
<task-list>
loading...
</task-list>
</body>

</html>


config.js

System.config({
//use typescript for compilation
transpiler: 'typescript',
//typescript compiler options
typescriptOptions: {
emitDecoratorMetadata: true
},
//map tells the System loader where to look for things
map: {
app: "./app",
'@angular': 'https://npmcdn.com/@angular',
'rxjs': 'https://npmcdn.com/rxjs@5.0.0-beta.6'
},
//packages defines our app package
packages: {
app: {
main: './main.ts',
defaultExtension: 'ts'
},
'@angular/core': {
main: 'index.js',
defaultExtension: 'js'
},
'@angular/compiler': {
main: 'index.js',
defaultExtension: 'js'
},
'@angular/common': {
main: 'index.js',
defaultExtension: 'js'
},
'@angular/platform-browser-dynamic': {
main: 'index.js',
defaultExtension: 'js'
},
'@angular/platform-browser': {
main: 'index.js',
defaultExtension: 'js'
},
rxjs: {
defaultExtension: 'js'
}
}
});

app/main.ts


import {bootstrap} from '@angular/platform-browser-dynamic';
import {TaskList} from './taskList.component';
bootstrap(TaskList, []).catch(err => console.error(err));


app/taskList.component.ts


/* Import Component module from angular library */
import {Component} from '@angular/core'

/* import OnInit */
import {OnInit} from '@angular/core'


/* import service */
import {TaskService} from './task.service'




/* create TaskList class decorator */
/* define selector of component */
/* include HTML file as template */
@Component ({
selector: 'task-list',
templateUrl: 'app/task-list.html',
providers: [TaskService]
})

/* create TaskList class */
/* Export TaskList Class */

export class TaskList implements OnInit {

private tasks
private taskTitle = ''

constructor(private taskService:TaskService){
this.tasks = []
}

ngOnInit(){
this.tasks = this.taskService.getTasks()
}

addTask(taskTitle){
if(taskTitle !='' && taskTitle){
this.taskService.addTask(taskTitle)
}
this.taskTitle = ''
}
deleteTask(taskIndex){
this.taskService.deleteTask(taskIndex)
}

}


app/task.service.ts


/* Import Injectable module from Angular 2 */

import {Injectable} from '@angular/core'

/* Create and export TaskService class */

/*@Injectable()*/
export class TaskService{

/* create empty tasks property */
private tasks = []

addTask(task){
this.tasks.push(task)
}

deleteTask(taskIndex){

delete(this.tasks[taskIndex])

}

getTasks(){
return this.tasks;
}



}


app/task-list.html




<div class="container">
<h1>Task List</h1>

<table class="table table-striped">
<tr>
<td width="200">Title</td>
<td width="70">Delete</td>
</tr>
<tr *ngFor="#task of tasks; #i = index">
<td>{{task}}</td>
<td>
<input type="button" value="Delete" (click)="deleteTask(i)">
</td>

</tr>

</table>

<br/>
<br/>
<p>Add Task</p>
<input type="text" [(ngModel)]="taskTitle" placeholder="Task Title" class="form-control">
<br/>
<input type="button" value="Add" (click)="addTask(taskTitle)" class="btn btn-primary pull-right">
<br/>
<br/>
<br/>
<br/>
<p class="text-center"><a href="http://learningturn.com/angular-2/angular-2-create-inject-service-examples/">Read Full Tutorial: Angular 2 Create And Inject Service With Examples</a></p>
</div>

Comments

Popular posts from this blog

How to Password Protect a Directory on Your Website

Password protecting a directory on your site is actually fairly easy. Webmasters typically want to protect a directory if they have information that they want to make available only to a selected number of people. This guide teaches how you can make a folder on  your website  accessible only to people with the appropriate password. If Your Web Host Has a Control Panel Before you dive into the task of manually password-protecting a directory using Apache's built-in facilities, you might want to check out your web host's control panel to see if they already provide the facility for protecting directories. In my experience, many commercial web hosts already provide an easy way for you to password-protect your directories. If such facility is already available, it's probably best to use it since it will save you time, particularly if you are not familiar with shell command lines and editing of .htaccess files. Otherwise, read on. System Requirements ...

Apple iOS 10.2 Is Now Available: What Is Included In The Update?

Apple has released iOS 10.2 to the general public today. The last time that Apple launched an iOS update was on October 31st with iOS 10.1.1. On that same day, Apple released the developer preview of iOS 10.2. To work out the kinks, Apple iOS 10.2 went through seven beta tests before the public release. This update includes several major features and many bug fixes. You can install iOS 10.2 by connecting your device to iTunes or downloading it by going to  Settings > General > Software Update . The iOS 10.2 update is available for the following devices: iPhone 5 and later, iPad 4th generation and later and iPod touch 6th generation and later. What Is Included In The Update? iOS 10.2 has several features worth pointing out: - New TV App Apple released a new TV app that provides recommendations for new movies and TV shows in the "Watch Now" section and to discover new apps and new iTunes releases in the "Store" section. The "Up Next" ...

AngularJS - Tables

Table data is normally repeatable by nature. ng-repeat directive can be used to draw table easily.  Following example states the use of ng-repeat directive to draw a table. <table> <tr> <th> Name </th> <th> Marks </th> </tr> <tr ng-repeat = "subject in student.subjects" > <td> {{ subject.name }} </td> <td> {{ subject.marks }} </td> </tr> </table> Table can be styled using CSS Styling. <style> table , th , td { border : 1px solid grey ; border - collapse : collapse ; padding : 5px ; } table tr : nth - child ( odd ) { background - color : #f2f2f2; } table tr : nth - child ( even ) { background - color : #ffffff; } </style> Example Following example will showcase all the above mentioned directive. <html> <head> <...