The code given below demonstrate the following:
This is how the screenshot of the table looks like:
The code is designed as following:
export class Teacher { constructor ( public id: number, public name: string, public subject: string, public address: string, public mobile: number ) { } }
import { Component } from '@angular/core'; import {Teacher} from './teacher'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { title = 'Tutosphere'; id = 1; teacher = new Teacher(0, '', '', '', 0); TEACHERS = [ new Teacher(this.id, 'Adarsh', 'Physics', 'Wilmington', 8764562341) ]; addTeacher() { this.id += 1; const teacherEntry = new Teacher(this.id, this.teacher.name, this.teacher.subject, this.teacher.address, this.teacher.mobile); this.TEACHERS.push(teacherEntry); this.resetTeacher(); } deleteTeacher(id: number) { for (let i = this.TEACHERS.length - 1; i >= 0; i--) { if (this.TEACHERS[i].id === id) { this.TEACHERS.splice(i, 1); } } } resetTeacher() { this.teacher.name = ''; this.teacher.subject = ''; this.teacher.address = ''; this.teacher.mobile = 0; } }
</pre> <pre><div class="container"> <nav class="navbar navbar-expand-md navbar-dark bg-dark mb-4"> <a class="navbar-brand" href="#">{{title}}</a> <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <div class="collapse navbar-collapse" id="navbarSupportedContent"> <ul class="navbar-nav mr-auto flex-row"> <li class="nav-item dropdown"> <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> Links </a> <div class="dropdown-menu" aria-labelledby="navbarDropdown"> <a class="dropdown-item" href="#">Link 1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="#">Link 2</a> </div> </li> </ul> <ul class="navbar-nav flex-row ml-md-auto d-none d-md-flex"> <li class="nav-item"> <a class="nav-link" href="#">Signup</a> </li> <li class="nav-item"> <a class="nav-link" href="#">Login</a> </li> </ul> </div> </nav> <form #tableForm="ngForm"> <button type="button" class="btn btn-primary" data-toggle="modal" data-target="#addTeacher">Add Teacher</button> <input type="text" id="searchTextId" [(ngModel)]="searchText" name="searchText" placeholder="Search By Name"> </form> <div style="margin-top: 10px"> <table class="table"> <thead class="thead-light"> <th>Full Name</th> <th>Subject</th> <th>Address</th> <th>Mobile No.</th> <th>Actions</th> </thead> <tbody> <tr *ngFor="let teacher of (TEACHERS | searchByName: searchText)"> <td>{{teacher.name}}</td> <td>{{teacher.subject}}</td> <td>{{teacher.address}}</td> <td>{{teacher.mobile}}</td> <td><button type="button" class="btn btn-secondary btn-sm" (click)="deleteTeacher(teacher.id)">Delete</button></td> </tr> </tbody> </table> </div> <!-- Modal --> <div class="modal fade" id="addTeacher" tabindex="-1" role="dialog" aria-labelledby="addTeacherTitle" aria-hidden="true"> <div class="modal-dialog" role="document"> <form (ngSubmit)="addTeacher()" #addTeacherForm="ngForm"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="addTeacherTitle">Add Teacher Details</h5> <button type="button" class="close" data-dismiss="modal" aria-label="Close"> <span aria-hidden="true">×</span> </button> </div> <div class="modal-body"> <div class="form-group"> <label for="teacherName">Teacher Name</label> <input type="text" class="form-control" id="teacherName" [(ngModel)]="teacher.name" name="teacherName" placeholder="Enter Name"> </div> <div class="form-group"> <label for="subject">Subject</label> <input type="text" class="form-control" id="subject" [(ngModel)]="teacher.subject" name="subject" placeholder="Enter Subject"> </div> <div class="form-group"> <label for="address">Address</label> <input type="text" class="form-control" id="address" [(ngModel)]="teacher.address" name="address" placeholder="Enter Address"> </div> <div class="form-group"> <label for="mobile">Mobile No.</label> <input type="number" class="form-control" id="mobile" [(ngModel)]="teacher.mobile" name="mobile" placeholder="Enter Mobile Number"> </div> </div> <div class="modal-footer"> <button type="submit" class="btn btn-primary">Submit</button> <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button> </div> </div> </form> </div> </div> </div></pre> <pre>
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { FormsModule } from '@angular/forms'; import { AppComponent } from './app.component'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, FormsModule ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }
For adding a table row, the following needs to be paid attention to:
</pre> <pre><div class="modal fade" id="addTeacher" tabindex="-1" role="dialog" aria-labelledby="addTeacherTitle" aria-hidden="true"> <div class="modal-dialog" role="document"> <form (ngSubmit)="addTeacher()" #addTeacherForm="ngForm"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="addTeacherTitle">Add Teacher Details</h5> <button type="button" class="close" data-dismiss="modal" aria-label="Close"> <span aria-hidden="true">×</span> </button> </div> <div class="modal-body"> <div class="form-group"> <label for="teacherName">Teacher Name</label> <input type="text" class="form-control" id="teacherName" [(ngModel)]="teacher.name" name="teacherName" placeholder="Enter Name"> </div> <div class="form-group"> <label for="subject">Subject</label> <input type="text" class="form-control" id="subject" [(ngModel)]="teacher.subject" name="subject" placeholder="Enter Subject"> </div> <div class="form-group"> <label for="address">Address</label> <input type="text" class="form-control" id="address" [(ngModel)]="teacher.address" name="address" placeholder="Enter Address"> </div> <div class="form-group"> <label for="mobile">Mobile No.</label> <input type="number" class="form-control" id="mobile" [(ngModel)]="teacher.mobile" name="mobile" placeholder="Enter Mobile Number"> </div> </div> <div class="modal-footer"> <button type="submit" class="btn btn-primary">Submit</button> <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button> </div> </div> </form> </div> </div> </div></pre> <pre>
addTeacher() { this.id += 1; const teacherEntry = new Teacher(this.id, this.teacher.name, this.teacher.subject, this.teacher.address, this.teacher.mobile); this.TEACHERS.push(teacherEntry); this.resetTeacher(); }
<button type="button" class="btn btn-secondary btn-sm" (click)="deleteTeacher(teacher.id)">Delete</button>
deleteTeacher(id: number) { for (let i = this.TEACHERS.length - 1; i &amp;amp;gt;= 0; i--) { if (this.TEACHERS[i].id === id) { this.TEACHERS.splice(i, 1); } } }
Check the details in relation to above on following pages:
If the rows are created using JSON data (companies in the example below), following code adds a row to the existing table. The addRow is a method invoked by the form submission.
<script> var helloApp = angular.module("helloApp", []); helloApp.controller("CompanyCtrl", function($scope) { $scope.companies = [ { 'name':'Infosys Technologies', 'employees': 125000, 'headoffice': 'Bangalore'}, { 'name':'Cognizant Technologies', 'employees': 100000, 'headoffice': 'Bangalore'}, ]; $scope.addRow = function(){ $scope.companies.push({ 'name':$scope.name, 'employees': $scope.employees, 'headoffice':$scope.headoffice }); $scope.name=''; $scope.employees=''; $scope.headoffice=''; }; )}; </script>
The directive ng-click is used in each row. The ng-click invokes the method removeRow whose code is represented below.
<script> var helloApp = angular.module("helloApp", []); helloApp.controller("CompanyCtrl", function($scope) { $scope.companies = [ { 'name':'Infosys Technologies', 'employees': 125000, 'headoffice': 'Bangalore'}, { 'name':'Cognizant Technologies', 'employees': 100000, 'headoffice': 'Bangalore'}, ]; $scope.removeRow = function(name){ var index = -1; var comArr = eval( $scope.companies ); for( var i = 0; i < comArr.length; i++ ) { if( comArr[i].name === name ) { index = i; break; } } if( index === -1 ) { alert( "Something gone wrong" ); } $scope.companies.splice( index, 1 ); }; )}; </script>
<!-- Code within body displaying table rows using ng-repeat repeater directive. Note the ng-click directive --> <table class="table"> <tr> <th>Name </th> <th>Employees </th> <th>Head Office </th> <th>Action </th> </tr> <tr ng-repeat="company in companies"> <td> </td> <td> </td> <td> </td> <td> <input type="button" value="Remove" class="btn btn-primary" ng-click="removeRow(company.name)"/> </td> </tr> </table></pre> <pre>
The above code along with demo and the details could also be found on the following pages:
What revolutionary technologies and industries will define the future of business in 2025? As we…
For data scientists and machine learning researchers, 2024 has been a landmark year in AI…
ChatGPT Canvas is a cutting-edge, user-friendly platform that simplifies content creation and elevates collaboration. Whether…
Knowing when to use the LLM such as the ChatGPT O1 model is key to…
In recent years, artificial intelligence (AI) has evolved to include more sophisticated and capable agents,…
Adaptive learning helps in tailoring learning experiences to fit the unique needs of each student.…
View Comments
If here we want to limit the addition of rows to only one row in table ,how should we proceed....http://plnkr.co/edit/lmm1ugAgkI0lvlkPZPXe?p=preview....here add row display the first row then after row should be appended.If user now submits nothing should happen ..ne pointers on this
with internet explorer 9.0 ,its not refreshing the array.some bugs are coming..can u help how to dynamically delete rows using angularjs in IE 9.0
i am trying to make this and its not working
https://jsfiddle.net/shakalya/ufvcspof/
i dont know what ami making wrong??