Wednesday, 15 April 2015

Add or remove data in html table using AngularJS

Today I am working on generating json data into a table and suddenly I thought of why not make it more dynamic, so that I can add row or remove row runtime. So then I came up with two javascript array functions push and splice which help me work out my idea. So I first used ng-repeat to populate the html table and just added one more column in the table which consists of a "remove" link which removes the row it consists of and a text field and a button to add the text value into the table. It's so dynamic, page is never reloaded, no tension of losing sessions. Just go through this tutorial and do comment if you have any questions.

<html ng-app="app">
<head>
<title>
    Add to remove from rows from table.
</title>
<script src= "http://ajax.googleapis.com/ajax/libs/angularjs/1.2.26/angular.min.js"></script>
<script type="text/javascript">
    app = angular.module('app',[]);
    app.controller('MyCtrl',function($scope) {
        $scope.myData = [];
        $scope.addData = function() {
            $scope.myData.push($scope.inData);
            $scope.inData="";
        }
        $scope.removeData = function(selData) {
            $scope.myData.splice($scope.myData.indexOf(selData),1);
        }
    });
</script>
</head>
<body ng-controller="MyCtrl">
<label>Enter data to add : </label>
<input type="text" name="inData" ng-model="inData" />
<input type="button" ng-click="addData()" value="Add Data" />
<table border="1">
    <tr>
        <th>Added Data</th>
    </tr>
    <tr ng-repeat="data in myData" >
        <td>{{data}}</td>
        <td><a href="" ng-click="removeData(data)">Remove</a></td>
    </tr>
</table>
</body>
</html>

 


Added Data
{{data}}Remove

Creating service and injecting dependencies with AngularJS

Hello everyone. As I am new to AngularJS and I am finding this framework app tremendously exciting making your web programming so simple and simple for users also. Today I came up with using service as dependency injection into the controller which is actually a part of user interaction. This is a small calculator program that uses has functions one for addition and another for multiplication. Just go through it and I am sure you will find some stuff if you really want to get through this framework.


<html ng-app="app">
<head>
<title>
    Injecting dependency in services.
</title>
<script src= "http://ajax.googleapis.com/ajax/libs/angularjs/1.2.26/angular.min.js"></script>
<script type="text/javascript">
    app = angular.module('app',[]);
    //Creating service with two functions which will be injected later on into the controller.
    app.service('CalcService',function() {
        this.Add = function(a,b) {
            return parseFloat(a) + parseFloat(b);
        };
        this.Multiply = function(a,b) {
            return a * b;
        };
    });
   // You can find how CalcService is injected into the controller
    app.controller('MainCtrl',function($scope,CalcService) {
        $scope.AddNumbers = function() {
        $scope.resultNum = CalcService.Add($scope.firstNum,$scope.secondNum);
        };
        $scope.MultiplyNumbers = function() {
        $scope.resultNum = CalcService.Multiply($scope.firstNum,$scope.secondNum);
        };
    });

</script>
</head>
<body ng-controller="MainCtrl">
<label>Enter First Number : </label>
<input type="text" name="firstNum" ng-model="firstNum" value="" /><br />
<label>Enter Second Number : </label>
<input type="text" name="secondNum" ng-model="secondNum" value="" /><br />
<input type="button" value="Multiply Number" ng-click="MultiplyNumbers()" / ><br />
<span>Result Value : {{resultNum}}</span>
</body>
</html>




Result Value : {{resultNum}}