אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » פיתוח אינטרנט » jQuery Scripts » jQuery ו-MooTools

jQuery ו-MooTools

רן בר-זיק אוגוסט 8, 2010 8:06 am אין תגובות

כך משתמשים בשתי ספריות JavaScript בדף אחד

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.

jQuery ו-MooTools הן שתי ספריות JavaScript שמסייעות לנו לכתוב ג'אווהסקריפט במהירות וביעילות חסרת תקדים. בדרך כלל רוב המתכנתים משתמשים באחת מהספריות כאשר הפופולריות של jQuery היא רבה הרבה יותר.

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

מדובר במצבים לא אידיאליים. כיוון שאז אנו צריכים להעלות את שתי הספריות שכל אחת שוקלת בערך כ-60 קילובייט וגם יש בעיית ביצועים. הדבר הטוב ביותר הוא לעבוד עם ספריה אחת ואם אנו עוברים לפתח על ג'ומלה או מערכת אחרת המשתמשת ב-MooTools אז פשוט להשקיע את הזמן וללמוד MooTools. אבל בדיוק בשביל המצבים הבלתי אידיאליים האלו, יש לנו את jQuery no conflict שנועד לטפל באינטגרציה של jQuery היכן שיש כבר ספריה אחרת (MooTools לצורך העניין).

על מנת להבין את הפתרון, חייבים להבין את הבעיה. הבעיה היא שגם MooTools וגם jQuery משתמשות ב-$ כפונקציה מובילה. אם נשתמש בשתיהן בלי הכנה מוקדמת, ספריה אחת תדרוס את השניה. לפיכך עלינו לבצע מעשה שיאפשר לנו להשתמש ב-$ (או בפתרון אחר) בשתי הספריות.

שימוש ב-$ בשתי הספריות

אחד מהפתרונות היותר אלגנטיים הוא להשתמש ב-jQuery.noConflict. ראשית אנו נכלול את הקובץ של הספריה השניה (לצורך העניין MooTools) ואז את קובץ הספריה של jQuery. אחרי כן אנו נשתמש בפונקצית noconflict כדי לכתוב גם jQuery עם $ וגם MooTools עם $


<script type="text/javascript" src="https://internet-israel.com/internet_files/mootools/mootools.js"></script>
<script type="text/javascript" src="https://internet-israel.com/scripts/jquery.js"></script>
<script type="text/javascript">

jQuery.noConflict();
// Put all your code in your document ready area
jQuery(document).ready(function($){ // Do jQuery stuff using $
       $("#jqueryDiv").bind("click", function(){
                $(this).css('color', 'red');
        });
});

window.addEvent('domready', function() { //Do MooTools stuff using $
    $('mooToolsDiv').addEvent('click', function(){
        this.setStyle('color', 'blue');
        });

});

</script>

שימו לב לכמה דברים, ראשית הדבר הראשון שרץ, לפני MooTools או jQuery זה jQuery.noConflict. דבר שני הוא שקובץ ה-MooTools נמצא לפני קובץ ה-jQuery. דבר שלישי הוא שבאירוע של doument.ready של jQuery אני מעביר את הפרמטר $.

לא הבנתם? אתם מוזמנים לדוגמא עובדת: קישור לדוגמא חיה ועובדת.

דריסת ה-$ של jQuery

פתרון אחר, מעט פחות אלגנטי אבל עדיין עובד, הוא להציב קודם כל את jQuery.js ואז את קובץ MooTools. תתבצע דריסה של $ ויהיה אפשר להפעיל את jQuery על ידי שימוש בפונקצית jquery ולא בפונקצית $. נשמע מסובך? שימו לב לדוגמא הבאה:


<script type="text/javascript" src="https://internet-israel.com/scripts/jquery.js"></script>
<script type="text/javascript">
jQuery.noConflict();
</script>

<script type="text/javascript" src="https://internet-israel.com/internet_files/mootools/mootools.js"></script>
<script type="text/javascript">

// Put all your code in your document ready area
jQuery(document).ready(function(){ // Do jQuery stuff woth jQuery
       jQuery("#jqueryDiv").bind("click", function(){
                jQuery(this).css('color', 'red');
        });
});

window.addEvent('domready', function() { //Do MooTools stuff with $
    $('mooToolsDiv').addEvent('click', function(){
        this.setStyle('color', 'blue');
        });

});

כאן כדאי לשים לב לשני דברים – ראשית, jQuery כאמור מגיע לפני MooTools ואני משתמש ב-jquerynoconflict לפני ש-MooTools נטען.

במקום $ אני משתמש ב-jQuery. $ משמש אך ורק את MooTools.

והנה דוגמא עובדת.

אגב, למי שצריך פלאגין טוב לג'ומלה שטוען jQuery – אני ממליץ על Core Design Web Gallery plugin שמכניס את jQuery לפני MooTools וגם מכניס noConflict באופן אוטומטי.

ותודה לפריה דווה על הרעיון.

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
MooTools ג'אווה סקריפט ו-jQuery באתרי אינטרנט ספרית jQuery

השארת תגובה

ביטול

ללמוד ג'אווהסקריפט בעברית

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-2000 תומכים - בואו ללמוד עכשיו איך לתכנת.

רשימת הנושאים
  • מדריכים
    • ריאקט
    • טייפסקריפט
    • ECMAScript 6
    • ES20XX
    • Node.js
    • Express
    • רספברי פיי
    • Babel
    • docker
    • MongoDB
    • Git
    • לימוד MySQL
    • SASS
    • jQuery
    • CSS3
    • HTML 5
    • SVN
    • LESS
  • פיתוח אינטרנט
    • פתרונות ומאמרים על פיתוח אינטרנט
    • jQuery Scripts
    • jQuery למתקדמים
    • יסודות בתכנות
    • נגישות אינטרנט
  • חדשות אינטרנט
  • מידע כללי על אינטרנט
    • רשת האינטרנט
    • בניית אתרי אינטרנט
  • rss logo

    לכל המאמרים

    לכל המאמרים שפורסמו באינטרנט ישראל משנת 2008 ועד עכשיו.
  • rss logo

    RSS Feed

    משתמשים בקורא RSS? אם כן, עקבו אחרי אינטרנט ישראל באמצעות פיד ה-RSS!
    מה זה RSS?
  • Twitter logo

    עקבו אחרי בטוויטר

    בחשבון הטוויטר שלי אני מפרסם עדכונים מהירים על חדשות בתחום התכנות והיזמות, התרעות על מצבי חירום ורכילות בוערת על תחום הווב.
    מה זה טוויטר?
  • facebook like image

    ערוץ הטלגרם של אינטרנט ישראל

    בערוץ הטלגרם של אינטרנט ישראל אני מפרסם את הפוסטים של באתר וכן עדכונים טכנולוגיים נוספים.
    מה זה טלגרם?
  • github logo

    הפרויקטים שלי בגיטהאב

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

כל הזכויות שמורות לרן בר-זיק ולאינטרנט ישראל | מדיניות הפרטיות של אתר אינטרנט ישראל | אתר אינטרנט ישראל נגיש לפי תקן WCAG 2.0 AA | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

גלילה לראש העמוד