נגישות       נגישות
שינוי גודל טקסט:
א א א
שינוי צבעי האתר:
? מקשי קיצור:

לחיצה חוזרת ונשנית על המקש Tab תעביר אתכם בין הקישורים והאזורים השונים בעמוד.

הפעלת מקשי הקיצור תלויה בדפדפן שבו אתם משתמשים.

Internet Explorer, Chrome ובגרסאות ישנות של Firefox: לחצו על מקש Alt ועל מקש המספר או האות על-פי הרשימה. ב Firefox 3 ומעלה: לחצו על המקשים Alt + Shift + המספר או האות.

S - עבור לתוכן הדף
L - חיפוש
1- עמוד הבית
2 - פרוייקטים
3 - מדריכים
4 - אודות
5 - צרו קשר
6 - הצהרת נגישות
 

מדריך אנגולר- controllers, directives, events

מחבר:
בתאריך:

מדריך זה מבוסס על מדריכים קודמים בסדרה, ומניח שיש לכם ידע מוקדם באנגולר. המדריכים שעליהם מבוסס מדריך זה הם:

במדריך זה נפתח את האפליקציה הבאה באמצעות AngularJS. אתם מוזמנים לנסות את האפליקציה בעצמכם. הזינו לטופס מודל מכונית ומחיר, ולחצו על "הוסף" כדי להוסיף לרשימה.

רשימת דגמי רכבים ומחיר

  • {{carModel.name}} - {{carModel.price | currency:"$":0}}

{{addModelError}}





 

ניתן להוריד את קוד המדריך מ-github: דוגמת קוד אנגולר

 

ה-HTML

נגדיר את האפליקציה באמצעות ng-app:

ng-app="myApp"

נגדיר את הקונטרולר באמצעות ng-controller:

ng-controller="carListCtrl"

ניצור רשימה שתתעדכן באופן דינמי בשמות הרכבים ומחירם באמצעות ng-repeat:

<ul>
<li ng-repeat="carModel in carModels"> {{carModel.name}} - {{carModel.price}}</li>
</ul>

מכיוון שאנחנו מעוניינים להציג את המחיר בדולרים ובמספרים שלמים נשתמש בפילטר אנגולרי:

{{carModel.price | currency:"$":0}}

נגדיר את השדות שאליהם נזין את שמות הרכבם ומחירם באמצעות ng-model:

<input type="text" ng-model="newCarModel">
                        
<input type="text" ng-model="newPrice">

לחיצה על הכפתור (ng-click) תקרא לפונקציה addItem, ותעביר את הנתונים החדשים שהוזנו לטופס:

<button ng-click="addItem(newCarModel, newPrice)">+ Add model and price</button>

כך נראה קוד ה-HTML המלא:

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
    <meta charset="UTF-8">    
    <title>Angular tutorial</title>
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.min.js"></script>
</head>
<body dir="ltr">
  <div ng-controller="carListCtrl">

    <h3>List of car models</h3>
            
      <ul>
        <li ng-repeat="carModel in carModels">{{carModel.name}} - {{carModel.price | currency:"$":0}}</li>
      </ul>
                 
      <p class="error">{{addModelError}}</p>
            
      <label>Car model name: <input type="text" ng-model="newCarModel"></label>
            
      <br /><br />
            
      <label>Car model price: <input type="text" ng-model="newPrice"></label>
            
      <br /><br />
            
      <button ng-click= "addItem(newCarModel, newPrice)">+ Add model and price</button>

  </div>
</div>

 

קוד האנגולר

ניצור את האפליקציה, שנקרא לה myApp:

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

בקונטרולר carListCtrl, המערך carModels יכיל את הנתונים שיוצגו ברשימה. הפונקציה addItem עושה ולידציה בסיסית לנתונים. במידה ותמצא שגיאה, ערך הודעת השגיאה יעדכן את המשתנה addModelError, שיוצג באופן אוטומטי.

ובמידה והנתונים שהזין המשתמש מספקים את הדרישות, יתווסף פריט חדש למערך carModels, והרשימה שמוצגת למשתמש תתעדכן באופן אוטומטי.

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

myApp.controller('carListCtrl', function($scope){
    $scope.carModels = [
        {name: "Audi", price: "30000"},
        {name: "Jaguar", price: "60000"},
        {name: "Sussita", price: "2500"},
    ];
    
    $scope.addItem = function(newCarModel, newPrice){
        $scope.addModelError = "";
        
        if(newCarModel === undefined || newCarModel == "" || newPrice === undefined || newPrice == ""){
            $scope.addModelError = "Please enter new car model and price.";
        } else if(!parseInt(newPrice)) {
            $scope.addModelError = "Please provide a number as a price.";
        } else if(/[^a-zA-Z ]/.test(newCarModel) || newCarModel.length < 3) {
            $scope.addModelError = "Please provide a valid car model name.";
        } else {
            $scope.carModels.push({
                name : newCarModel,
                price: parseInt(newPrice)
            }); 
        }
    };
});

לכל מדריכי ה- AngularJS

הוסף תגובה חדשה

 

= 8 + 9

תמונת המגיב

רונן בתאריך: 22.11.2016

תודה רבה פשוט וקליל!!

תמונת המגיב

יוסי בן הרוש בתאריך: 22.11.2016

תודה רונן. זה הרעיון. להסביר גם דברים שנראים מורכבים בדרך הפשוטה ביותר האפשרית.