אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » מדריכים » CSS3 » העולם המופלא של צורות ב-CSS

העולם המופלא של צורות ב-CSS

רן בר-זיק יולי 6, 2014 7:33 am אין תגובות

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

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

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

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

עיגולים היא דוגמה טובה. בשימוש בתכונת round border אפשר ליצור עיגולים בכל מני צבעים ללא כל בעיה. הנה דוגמה:

הקוד שיוצר את הפלא הקטן הזה הוא:


#example_circle {
	background-color: red;
	border-radius: 50%;
	width: 200px;
	height: 200px; 
}

טוב, את זה כמעט כולם יודעים לעשות, אבל מעטים יודעים שאפשר לעשות צורות יותר שימושיות – כמו למשל משהו כזה שיצרתי לא מזמן:

דוגמה לצורת סימניה
דוגמה לצורת סימניה

בעבר דבר כזה היה מריץ אותי ישר אל העורך הגרפי כדי להתחיל בחיתוך – אבל אפשר ליצר כזה דבר בקלות עם CSS:


#bookmark_example {
	width: 0;
	height: 30px;
	border-left: 45px solid #FFC20F;
	border-right: 45px solid #FFC20F;
	border-bottom: 40px solid transparent;
}

היתרונות ביצירת דבר כזה עם CSS ולא עם גרפיקה הם עצומים – בכל מה שקשור לשינויים ולהתאמות (שתמיד מתקיימות). הרבה יותר קל לשנות רוחב של איזה div כמו במקרה לעיל מאשר לחתוך שוב ולהעלות. זה גם הרבה יותר ידידותי לרוחב הפס ולביצועים.

כמובן שהעושר של הצורות ב-CSS היא עצומה. אחת הדוגמאות שאני ממש אוהב הוא המגן דוד:


#star-six {
	width: 0;
	height: 0;
	border-left: 50px solid transparent;
	border-right: 50px solid transparent;
	border-bottom: 100px solid red;
	position: relative;
}
#star-six:after {
	width: 0;
	height: 0;
	border-left: 50px solid transparent;
	border-right: 50px solid transparent;
	border-top: 100px solid red;
	position: absolute;
	content: "";
	top: 30px;
	left: -50px;
}

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

את זה עשיתי עם קוד קצת ארוך:


#heart {
    position: relative;
    width: 100px;
    height: 90px;
}
#heart:before,
#heart:after {
    position: absolute;
    content: "";
    left: 50px;
    top: 0;
    width: 50px;
    height: 80px;
    background: red;
    -moz-border-radius: 50px 50px 0 0;
    border-radius: 50px 50px 0 0;
    -webkit-transform: rotate(-45deg);
       -moz-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
         -o-transform: rotate(-45deg);
            transform: rotate(-45deg);
    -webkit-transform-origin: 0 100%;
       -moz-transform-origin: 0 100%;
        -ms-transform-origin: 0 100%;
         -o-transform-origin: 0 100%;
            transform-origin: 0 100%;
}
#heart:after {
    left: 0;
    -webkit-transform: rotate(45deg);
       -moz-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
         -o-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: 100% 100%;
       -moz-transform-origin: 100% 100%;
        -ms-transform-origin: 100% 100%;
         -o-transform-origin: 100% 100%;
            transform-origin :100% 100%;
}

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

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

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

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

השארת תגובה

ביטול

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

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-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 | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

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