lalitaly
1/20/2016 - 9:49 AM

EGCO427: AngularJS Introduction

EGCO427: AngularJS Introduction

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<title>AngularJS Introlduction</title>
	<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
	<link rel="stylesheet" href="">
</head>
<body>
	<!-- Example 1 -->
	<div ng-app="">
		<p>Input something in the input box:</p>
		<p>Name : <input type="text" ng-model="name" placeholder="Enter name here"></p>
		<h1>Hello {{name}}</h1>
	</div>
	<!-- Example 2 -->
	<div ng-app="">
	 	<p>Name: <input type="text" ng-model="name"></p>
	 	<p ng-bind="name"></p>
	</div>

	<!-- Example 3 -->
	<div ng-app="" ng-init="firstName='John'">
		<p>The name is <span ng-bind="firstName"></span></p>
	</div>

	<!-- Example 4 -->
	<div data-ng-app="" data-ng-init="firstName='John'">
		<p>The name is <span data-ng-bind="firstName"></span></p>
	</div>

	<!-- Example 5 -->
	<div ng-app="">
 		<p>My first expression: {{ 5 + 5 }}</p>
	</div>

	<!-- Example 6 -->
	<div ng-app="">
  		<p>Name: <input type="text" ng-model="name"></p>
  		<p>{{name}}</p>
	</div>
	<!-- Example 7 -->
	<div ng-app="myApp" ng-controller="myCtrl">
		First Name: <input type="text" ng-model="firstName"><br>
		Last Name: <input type="text" ng-model="lastName"><br>
		<br>
		Full Name: {{firstName + " " + lastName}}
	</div>

	<script>
		var app = angular.module('myApp', []);
		app.controller('myCtrl', function($scope) {
		    $scope.firstName= "John";
		    $scope.lastName= "Doe";
		});
	</script>
	<!-- Example 8 -->
	<div ng-app="" ng-init="myCol='lightblue'">
		<input style="background-color:{{myCol}}" ng-model="myCol" value="{{myCol}}">
	</div>
	<!-- Example 9 -->
	<div ng-app="" ng-init="quantity=1;cost=5">
		<p>Total in dollar: {{ quantity * cost }}</p>
	</div>
	<!-- Example 10 -->
	<div ng-app="" ng-init="quantity=1;cost=5">
		<p>Total in dollar: <span ng-bind="quantity * cost"></span></p>
	</div>
	<!-- Example 11 -->
	<div ng-app="" ng-init="firstName='John';lastName='Doe'">
		<p>The name is {{ firstName + " " + lastName }}</p>
	</div>
	<!-- Example 12 -->
	<div ng-app="" ng-init="firstName='John';lastName='Doe'">
		<p>The name is <span ng-bind="firstName + ' ' + lastName"></span></p>
	</div>
	<!-- Example 13 -->
	<div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}">
		<p>The name is {{ person.lastName }}</p>
	</div>
	<!-- Example 14 -->
	<div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}">
		<p>The name is <span ng-bind="person.lastName"></span></p>
	</div>

	<!-- Example 15 -->
	<div ng-app="" ng-init="points=[1,15,19,2,40]">
		<p>The third result is {{ points[2] }}</p>
	</div>

	<!-- Example 16 -->
	<div ng-app="" ng-init="points=[1,15,19,2,40]">
		<p>The third result is <span ng-bind="points[2]"></span></p>
	</div>
	
	<!-- Example 17 -->
	<div ng-app="myApp" ng-controller="myCtrl">
		{{ firstName + " " + lastName }}
	</div>

	<script>

		var app = angular.module("myApp", []);

		app.controller("myCtrl", function($scope) {
		    $scope.firstName = "John";
		    $scope.lastName = "Doe";
		});

	</script>
	<!-- Example 18 -->
	<div ng-app="myApp" w3-test-directive></div>

	<script>
		var app = angular.module("myApp", []);

		app.directive("w3TestDirective", function() {
		    return {
		        template : "I was made in a directive constructor!"
		    };
		});
	</script>
	<!-- Example 19 -->
	<div ng-app="myApp" ng-controller="myCtrl">
		{{ firstName + " " + lastName }}
	</div>

	<script src="myApp.js"></script>
	<script src="myCtrl.js"></script>

	<!-- myApp.js  -->
	var app = angular.module("myApp", []);
	<!-- myCtrl.js -->
	app.controller("myCtrl", function($scope) {
	    $scope.firstName	= "John";
	    $scope.lastName= "Doe";
	});
	<!-- Example 20 -->
	<div ng-app="myApp" ng-controller="myCtrl">
		{{ firstName + " " + lastName }}
	</div>

	<script>
		var app = angular.module("myApp", []);
		app.controller("myCtrl", function($scope) {
		    $scope.firstName = "John";
		    $scope.lastName = "Doe";
		});
	</script>
	<!-- Example 21 -->

	<div ng-app="" ng-init="quantity=1;price=5">
		Quantity: <input type="number"	ng-model="quantity">
		Costs:    <input type="number" ng-model="price">
		Total in dollar: {{ quantity * price }}
	</div>
	<!-- Example 22 -->
	<div ng-app="" ng-init="names=['Jani','Hege','Kai']">
	  <ul>
	    <li ng-repeat="x in names">
	      {{ x }}
	    </li>
	  </ul>
	</div>
	<!-- Example 23 -->
	<div ng-app="" ng-init="names=[
	{name:'Jani',country:'Norway'},
	{name:'Hege',country:'Sweden'},
	{name:'Kai',country:'Denmark'}]">
		<ul>
		  <li ng-repeat="x	in names">
		    {{ x.name + ', ' + x.country }}
		  </li>
		</ul>
	</div>
	<!-- Example 24 -->

	<w3-test-directive></w3-test-directive>

	<script>
		var app = angular.module("myApp", []);
		app.directive("w3TestDirective", function() {
		    return {
		        template : "<h1>Made by a directive!</h1>"
		    };
		});
	</script>
	<!-- Example 25 -->
	<div ng-app="myApp" ng-controller="myCtrl">
	    Name: <input ng-model="name">
	</div>

	<script>
		var app = angular.module('myApp', []);
		app.controller('myCtrl', function($scope) {
		    $scope.name = "John Doe";
		});
	</script>
	<!-- Example 26 -->

	<div ng-app="myApp" ng-controller="myCtrl">
    Name: <input ng-model="name">
	    <h1>You entered: {{name}}</h1>
	</div>
	<!-- Example 27 -->
	<form ng-app="" name="myForm">
	    Email:
	    <input type="email" name="myAddress" ng-model="text">
	    <span ng-show="myForm.myAddress.$error.email">Not a valid e-mail address</span>
	</form>
	<!-- Example 28 -->
	<form ng-app="" name="myForm" ng-init="myText = 'post@myweb.com'">
	    Email:
	    <input type="email" name="myAddress" ng-model="myText" required></p>
	    <h1>Status</h1>
	    {{myForm.myAddress.$valid}}
	    {{myForm.myAddress.$dirty}}
	    {{myForm.myAddress.$touched}}
	</form>
	<!-- Example 29 -->
	<style>
		input.ng-invalid {
		    background-color: lightblue;
		}
	</style>

	<form ng-app="" name="myForm">
	    Enter your name:
	    <input name="myAddress" ng-model="text" required>
	</form>
	<!-- Example 30 -->
	<div ng-app="myApp" ng-controller="myCtrl">

		First Name: <input type="text" ng-model="firstName"><br>
		Last Name: <input type="text" ng-model="lastName"><br>
		<br>
		Full Name: {{firstName + " " + lastName}}

	</div>

	<script>
		var app = angular.module('myApp', []);
		app.controller('myCtrl', function($scope) {
		    $scope.firstName = "John";
		    $scope.lastName = "Doe";
		});
	</script>
	<!-- Example 31 -->
	<div ng-app="myApp" ng-controller="personCtrl">

		First Name: <input type="text" ng-model="firstName"><br>
		Last Name: <input type="text" ng-model="lastName"><br>
		<br>
		Full Name: {{fullName()}}

	</div>

	<script>
		var app = angular.module('myApp', []);
		app.controller('personCtrl', function($scope) {
		    $scope.firstName = "John";
		    $scope.lastName = "Doe";
		    $scope.fullName = function() {
		        return $scope.firstName + " " + $scope.lastName;
		    };
		});
	</script>
	<!-- Example 32 -->
	<div ng-app="myApp" ng-controller="personCtrl">

		First Name: <input type="text" ng-model="firstName"><br>
		Last Name: <input type="text" ng-model="lastName"><br>
		<br>
		Full Name: {{fullName()}}

	</div>

	<script>
		var app = angular.module('myApp', []);
		app.controller('personCtrl', function($scope) {
		    $scope.firstName = "John";
		    $scope.lastName = "Doe";
		    $scope.fullName = function() {
		        return $scope.firstName + " " + $scope.lastName;
		    };
		});
	</script>
	<!-- Example 33 -->
	<div ng-app="myApp" ng-controller="personCtrl">

		First Name: <input type="text" ng-model="firstName"><br>
		Last Name: <input type="text" ng-model="lastName"><br>
		<br>
		Full Name: {{firstName + " " + lastName}}

	</div>

	<script src="personController.js"></script>
	<!-- personController.js  -->
	angular.module('myApp', []).controller('personCtrl', function($scope) {
	    $scope.firstName = "John",
	    $scope.lastName = "Doe",
	    $scope.fullName = function() {
	        return $scope.firstName + " " + $scope.lastName;
	    }
	});
	<!-- Example 34 -->
	<div ng-app="myApp" ng-controller="namesCtrl">

	<ul>
	  <li ng-repeat="x in names">
	    {{ x.name + ', ' + x.country }}
	  </li>
	</ul>

	</div>

	<script src="namesController.js"></script>
	<!-- namesController.js -->
	angular.module('myApp', []).controller('namesCtrl', function($scope) {
	    $scope.names = [
	        {name:'Jani',country:'Norway'},
	        {name:'Hege',country:'Sweden'},
	        {name:'Kai',country:'Denmark'}
	    ];
	});
	<!-- Example 35 -->
	<!-- Example 36 -->
	<!-- Example 37 -->
	<!-- Example 38 -->
	<!-- Example 39 -->
</body>
</html>
/*-------------------------
	Simple reset
--------------------------*/


*{
	margin:0;
	padding:0;
}


/*-------------------------
	General Styles
--------------------------*/


body{
	font:15px/1.3 'Open Sans', sans-serif;
	color: #5e5b64;
	text-align:center;
	    margin-top: -85px;
}

a, a:visited {
	outline:none;
	color:#389dc1;
}

a:hover{
	text-decoration:none;
}

section, footer, header, aside, nav{
	display: block;
}


/*-------------------------
	The search input
--------------------------*/


.bar{
	background-color:#5c9bb7;

	background-image:-webkit-linear-gradient(top, #5c9bb7, #5392ad);
	background-image:-moz-linear-gradient(top, #5c9bb7, #5392ad);
	background-image:linear-gradient(top, #5c9bb7, #5392ad);

	box-shadow: 0 1px 1px #ccc;
	border-radius: 2px;
	width: 400px;
	padding: 14px;
	margin: 80px auto 20px;
	position:relative;
}

.bar input{
	background:#fff no-repeat 13px 13px;
	background-image:url();

	border: none;
	width: 100%;
	line-height: 19px;
	padding: 11px 0;

	border-radius: 2px;
	box-shadow: 0 2px 8px #c4c4c4 inset;
	text-align: left;
	font-size: 14px;
	font-family: inherit;
	color: #738289;
	font-weight: bold;
	outline: none;
	text-indent: 40px;
}

ul{
	list-style: none;
	width: 428px;
	margin: 0 auto;
	text-align: left;
}

ul li{
	border-bottom: 1px solid #ddd;
	padding: 10px;
	overflow: hidden;
}

ul li img{
	width:60px;
	height:60px;
	float:left;
	border:none;
}

ul li p{
	margin-left: 75px;
	font-weight: bold;
	padding-top: 12px;
	color:#6e7a7f;
}
var app = angular.module("instantSearch", []);

app.filter('searchFor', function() {
    return function(arr, searchString) {
        if (!searchString) {
            return arr;
        }
        var result = [];
        searchString = searchString.toLowerCase();
        angular.forEach(arr, function(item) {
            if (item.title.toLowerCase().indexOf(searchString) !== -1) {
                result.push(item);
            }
        });
        return result;
    };
});

app.controller('InstantSearchController', function($scope) {
            $scope.items = [{
                url: 'http://www.tutorialspoint.com/android/',
                title: 'Android tutorials',
                image: 'http://www.tutorialspoint.com/android/images/android-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/angularjs/',
                title: 'AngularJs Tutorials ',
                image: 'http://www.tutorialspoint.com/angularjs/images/angularjs-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/html5/',
                title: 'HTML5 Tutorials',
                image: 'http://www.tutorialspoint.com/html5/images/html5-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/css/',
                title: 'CSS Tutorials',
                image: 'http://www.tutorialspoint.com/css/images/css-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/java/',
                title: 'Java Tutorials',
                image: 'http://www.tutorialspoint.com/java/images/java-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/joomla/',
                title: 'Joomla Tutorials',
                image: 'http://www.tutorialspoint.com/joomla/images/joomla-mini-logo.jpg'
            }, {
                url: 'http://www.tutorialspoint.com/html/',
                title: 'HTML Tutorials ',
                image: 'http://www.tutorialspoint.com/html/images/html-mini-logo.jpg'
            }];
        });
<!DOCTYPE html>
<html>
	<head>
	    <meta charset="utf-8" />
	    <title>Learn AngularJS - Instant Search</title>
	    <link href="http://fonts.googleapis.com/css?family=Cookie|Open+Sans:400,700" rel="stylesheet" />
	    <link href="style.css" rel="stylesheet" />
	    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
	    <script src="script.js"></script>
	</head>

	<body ng-app="instantSearch" ng-controller="InstantSearchController">
	    <div class="bar">
	        <input type="text" ng-model="searchString" placeholder="Enter your search terms" />
	    </div>
	    <ul>
	        <li ng-repeat="i in items | searchFor:searchString">
	            <a href="{{i.url}}"><img ng-src="{{i.image}}" /></a>
	            <p>{{i.title}}</p>
	        </li>
	    </ul>
	</body>

</html>
/*-------------------------
	Simple reset
--------------------------*/


*{
	margin:0;
	padding:0;
}


/*-------------------------
	General Styles
--------------------------*/


body{
	font:15px/1.3 'Open Sans', sans-serif;
	color: #5e5b64;
	text-align:center;
	    margin-top: -77px;
}

a, a:visited {
	outline:none;
	color:#389dc1;
}

a:hover{
	text-decoration:none;
}

section, footer, header, aside, nav{
	display: block;
}


/*-------------------------
	The order form
--------------------------*/


form{
	background-color: #61a1bc;
	border-radius: 2px;
	box-shadow: 0 1px 1px #ccc;
	width: 400px;
	padding: 35px 60px;
	margin: 80px auto;
}

form h1{
	color:#fff;
	font-size:64px;
	font-family:'Cookie', cursive;
	font-weight: normal;
	line-height:1;
	text-shadow:0 3px 0 rgba(0,0,0,0.1);
}

form ul{
	list-style:none;
	color:#fff;
	font-size:20px;
	font-weight:bold;
	text-align: left;
	margin:20px 0 15px;
}

form ul li{
	padding:20px 30px;
	background-color:#e35885;
	margin-bottom:8px;
	box-shadow:0 1px 1px rgba(0,0,0,0.1);
	cursor:pointer;
}

form ul li span{
	float:right;
}

form ul li.active{
	background-color:#8ec16d;
}

div.total{
	border-top:1px solid rgba(255,255,255,0.5);
	padding:15px 30px;
	font-size:20px;
	font-weight:bold;
	text-align: left;
	color:#fff;
}

div.total span{
	float:right;
}
var app = angular.module('Order', []);

app.controller('OrderController', function($scope) {

    $scope.services = [{
        name: "Tutorials Development",
        price: "500",
        active: "true"
    }, {
        name: 'Tutorial Design',
        price: 300,
        active: false
    }, {
        name: 'Code Integration',
        price: 250,
        active: false
    }, {
        name: 'Training',
        price: 220,
        active: false
    }];

    $scope.toggleActive = function(s) {
        s.active = !s.active;
    };

    $scope.total = function() {
        var total = 0;
        angular.forEach($scope.services, function(s) {
            if (s.active) {
                total += s.price;
            }
        });
        return total;
    };
});
<!DOCTYPE html>
<html>
	<head>
	    <meta charset="utf-8" />
	    <title>Learn AngularJS - Order Form</title>
	    <link href="http://fonts.googleapis.com/css?family=Cookie|Open+Sans:400,700" rel="stylesheet" />
	    <link href="style.css" rel="stylesheet" />
	    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
	    <script src="script.js"></script>
	</head>

	<body ng-app="Order" ng-controller="OrderController">
	    <form>
	        <h1>List of Services</h1>
	        <ul>
	            <li ng-repeat="service in services" ng-class="{active:service.active}" ng-click="toggleActive(service)">
	                {{service.name}} <span>{{service.price|currency}}</span>
	            </li>
	        </ul>
	        <div class="total">Total: {{total()|currency}}</div>
	    </form>
	</body>
</html>
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>AngularJS Posting Login Form</title>
    <link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet">
  </head>
  <body>
    <div class="container">
      <h2>You have logged in successfully</h2>
    </div> 
  </body>
</html>
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>AngularJS Posting Login Form</title>
	<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
    <link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet">
	<style type="text/css">
		.login-form {
			max-width: 300px;
			margin: 0 auto;
		}
		#inputUsername {
		  margin-bottom: -1px;
		  border-bottom-right-radius: 0;
		  border-bottom-left-radius: 0;
		}
		#inputPassword {
			border-top-left-radius: 0;
  			border-top-right-radius: 0;
		}
	</style>
  </head>
  <body ng-app="postExample" ng-controller="PostController as postCtrl">
    <div class="container">
      <form class="login-form" ng-submit="postCtrl.postForm()">
        <h2>Please sign in</h2>
        <label for="inputUsername" class="sr-only">Username</label>
        <input type="text" id="inputUsername" class="form-control" placeholder="Username" required autofocus ng-model="postCtrl.inputData.username">
        <label for="inputPassword" class="sr-only">Password</label>
        <input type="password" id="inputPassword" class="form-control" placeholder="Password" required ng-model="postCtrl.inputData.password">
		<br>
		<div class="alert alert-danger" role="alert" ng-show="errorMsg">{{errorMsg}}</div>
        <button class="btn btn-lg btn-primary btn-block" type="submit">Sign in</button>
		
      </form>
    </div> 
	<script>
	angular.module('postExample', [])
	.controller('PostController', ['$scope', '$http', function($scope, $http) {
		
		this.postForm = function() {
		
			var encodedString = 'username=' +
				encodeURIComponent(this.inputData.username) +
				'&password=' +
				encodeURIComponent(this.inputData.password);
				
			$http({
				method: 'POST',
				url: 'check-login.php',
				data: encodedString,
				headers: {'Content-Type': 'application/x-www-form-urlencoded'}
			})
			.success(function(data, status, headers, config) {
				console.log(data);
				if ( data.trim() === 'correct') {
					window.location.href = 'success.html';
				} else {
					$scope.errorMsg = "Login not correct";
				}
			})
			.error(function(data, status, headers, config) {
				$scope.errorMsg = 'Unable to submit form';
			})
		}
		
	}]);
	</script>
  </body>
</html>
<?php 
if ( $_POST['username'] === 'admin' && 
	$_POST['password'] === 'admin' ) {
		echo 'correct';
} else {
		echo 'wrong'; 
}

?>


{ "records":[ {"Name":"Alfreds Futterkiste","City":"Berlin","Country":"Germany"}, {"Name":"Ana Trujillo Emparedados y helados","City":"México D.F.","Country":"Mexico"}, {"Name":"Antonio Moreno Taquería","City":"México D.F.","Country":"Mexico"}, {"Name":"Around the Horn","City":"London","Country":"UK"}, {"Name":"B's Beverages","City":"London","Country":"UK"}, {"Name":"Berglunds snabbköp","City":"Luleå","Country":"Sweden"}, {"Name":"Blauer See Delikatessen","City":"Mannheim","Country":"Germany"}, {"Name":"Blondel père et fils","City":"Strasbourg","Country":"France"}, {"Name":"Bólido Comidas preparadas","City":"Madrid","Country":"Spain"}, {"Name":"Bon app'","City":"Marseille","Country":"France"}, {"Name":"Bottom-Dollar Marketse","City":"Tsawassen","Country":"Canada"}, {"Name":"Cactus Comidas para llevar","City":"Buenos Aires","Country":"Argentina"}, {"Name":"Centro comercial Moctezuma","City":"México D.F.","Country":"Mexico"}, {"Name":"Chop-suey Chinese","City":"Bern","Country":"Switzerland"}, {"Name":"Comércio Mineiro","City":"São Paulo","Country":"Brazil"} ] }

<!DOCTYPE html>
<html lang="">
	<head>
		<meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title>Title Page</title>
		<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
		<!-- Bootstrap CSS -->
		<link href="http://netdna.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" rel="stylesheet">

		<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
		<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
		<!--[if lt IE 9]>
			<script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
			<script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
		<![endif]-->
	</head>
	<body>
		<h1 class="text-center">List of Country</h1>

		<div ng-app="myApp" ng-controller="customersCtrl"> 
		<table class="table table-hover">
			<thead>
				<tr>
					<th>Name</th>
					<th>City</th>
					<th>Country</th>
				</tr>
			</thead>
			<tbody>
				<tr ng-repeat="x in myData">
					<td>{{x.Name}}</td>
					<td>{{x.City}}</td>
					<td>{{x.Country}}</td>
				</tr>
			</tbody>
		</table>
</div>

	<script>
	var app = angular.module('myApp', []);
	app.controller('customersCtrl', function($scope, $http) {
	  $http.get("data.json").then(function (response) {
	      $scope.myData = response.data.records;
	  });
	});
	</script>



		<!-- jQuery -->
		<script src="http://code.jquery.com/jquery.js"></script>
		<!-- Bootstrap JavaScript -->
		<script src="http://netdna.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
	</body>
</html>