תחי ישראל - אין לנו ארץ אחרת

תחי ישראל -אין לנו ארץ אחרת

מדריך אנגולר- 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

 

אהבתם? לא אהבתם? דרגו!

0 הצבעות, ממוצע 0 מתוך 5 כוכבים

 

 

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

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

שימו לב! הסקריפטים במדריכים מיועדים למטרות לימוד בלבד. כשאתם עובדים על הפרויקטים שלכם אתם צריכים להשתמש בספריות וסביבות פיתוח מוכחות, מהירות ובטוחות.

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

השימוש שלך באתר מהווה ראייה להסכמתך עם הכללים והתקנות שנוסחו בהסכם תנאי השימוש.

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

 

 

ענה על השאלה הפשוטה הבאה כתנאי להוספת תגובה:

מתי הוקמה המדינה?

 

תמונת המגיב

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

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

תמונת המגיב

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

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