2015-10-16 22:06:59 +03:00
---
2024-10-21 00:46:35 +03:00
language: CSS
2015-10-16 22:06:59 +03:00
contributors:
- ["Kostas Bariotis", "http://kostasbariotis.com"]
filename: css-gr.html.markdown
2015-10-16 22:09:45 +03:00
lang: el-gr
2015-10-16 22:06:59 +03:00
---
2016-10-26 11:20:03 +03:00
Η αρχική μορφή του Παγκόσμιου Ιστού αποτελείτο απο καθαρό κείμενο, χωρίς οπτικά αντικείμενα. Με το πέρας
2015-10-16 22:16:56 +03:00
του χρόνου και την εξέλιξη των Φυλλομετρητών, ο ι πλούσιες σελίδες, σε οπτικά και πολυμεσικά αντικείμενα,
2016-10-26 11:20:03 +03:00
έγιναν καθημερινότητα.
2015-10-16 22:06:59 +03:00
Η CSS μας βοηθάει ν α διαχωρήσουμε το περιεχόμενο της σελίδας μας (HTML) απο την οπτική της περιγραφή.
Με την CSS ορίζουμε οπτικές ιδιότητες (χρώμα, μέγεθος, κλπ) σε HTML αντικείμενα (H1, div, κλπ).
```css
2016-10-26 11:20:03 +03:00
/* Τ α σχόλια εμφανίζονται εντός καθέτου-αστερίσκου, όπως εδώ.
2015-10-16 22:06:59 +03:00
Δεν υπάρχουν σχόλια μια γραμμής και πολλών. */
/* ####################
## ΚΑΝΟΝΕΣ
#################### */
2016-10-26 11:20:03 +03:00
/* ένας κανόνας χρησιμοποιείται γ ι α ν α στοχεύσουμε ένα αντικείμενο (selector). */
2015-10-16 22:06:59 +03:00
selector { property: value; /* περισσότερες ιδιότητες...*/ }
/*
2016-05-19 10:34:53 +03:00
Αυτό είναι ενα παράδειγμα αντικειμένου
2015-10-16 22:06:59 +03:00
< div class = 'class1 class2' id = 'anID' attr = 'value' otherAttr = 'en-us foo bar' / >
2016-05-19 17:16:11 +03:00
*/
2015-10-16 22:06:59 +03:00
/* Μπορούμε ν α το στοχεύσουμε με την χρήση CSS κλάσεων */
.class1 { }
/* Ή και με τις δύο κλάσεις! */
.class1.class2 { }
/* Κ α ι με το όνομα του */
div { }
/* Ή με το id του */
#anID { }
/* Ή με το γεγονός ότι περιέχει ενα attribute */
[attr] { font-size:smaller; }
/* Ή οτι το attribute αυτό έχει μια συγκεκριμένη τιμή */
[attr='value'] { font-size:smaller; }
/* Ξεκινάει απο το λεκτικό (CSS 3) */
[attr^='val'] { font-size:smaller; }
/* Καταλήγει σε αυτο το λεκτικό (CSS 3) */
[attr$='ue'] { font-size:smaller; }
/* Περιέχει κάποιο λεκτικό */
[otherAttr~='foo'] { }
[otherAttr~='bar'] { }
/* περιέχει το λεκτικό σε λίστα χωρισμένη με παύλες, δηλαδή: "-" (U+002D) */
[otherAttr|='en'] { font-size:smaller; }
/* Μπορούμε ν α προσθέσουμε μεταξύ τους selectors γ ι α ν α δημιουργήσουμε πιο αυστηρούς.
Δεν βάζουμε κενά ανάμεσα. */
div.some-class[attr$='ue'] { }
/* Μπορούμε ν α επιλέξουμε αντικείμενα που βρίσκονται μέσα σε άλλα. */
div.some-parent > .class-name { }
/* Ή κάποιο αντικείμενο απόγονο ανεξαρτήτου του βάθους της σχέσης τους. */
div.some-parent .class-name { }
/* ΠΡΟΣΟΧΗ: ο ίδιος selector χωρίς κενά έχει άλλο νόημα. (Άσκηση προς τον αναγνώστη) */
div.some-parent.class-name { }
/* Μπορούμε ν α επιλέξουμε αντικείμενα με βάση το αμέσως επόμενο αντικείμενο στο ίδιο επίπεδο. */
.i-am-just-before + .this-element { }
2015-10-16 22:27:30 +03:00
/* Ή οποιοδήποτε αντικείμενο που προηγείται */
2015-10-16 22:06:59 +03:00
.i-am-any-element-before ~ .this-element { }
/* Με την βοήθεια των ψευδο-κλάσεων μπορούμε ν α επιλέξουμε αντικείμενα που βρίσκονται σε μια
ορισμένη κατάασταση. */
/* π.χ. όταν ο κέρσορας είναι πάνω απο ένα αντικείμενο */
selector:hover { }
/* ή ένας υπερσύνδεσμος που πατήθηκε */
selector:visited { }
/* ή που δεν πατήθηκε */
selected:link { }
/* ή ένα αντικείμενο που επιλέχθηκε */
selected:focus { }
/* οποιοδήποτε αντικείμενο είναι το πρώτο παιδί των γονέων του */
selector:first-child {}
/* οποιοδήποτε αντικείμενο είναι το πρώτοτελευταίο παιδί των γονέων του */
selector:last-child {}
/* Όπως και με τις ψευδο-κλάσεις, τα ψευδο-αντικείμενα μας επιτρέπουν τα τροποοιήσουμε συγκεκριμένα
κομμάτια της σελίδας */
/* επιλέγει το ψευδο-αντικείμενο ακριβώς πριν απο το αντικείμενο */
selector::before {}
/* επιλέγει το ψευδο-αντικείμενο ακριβώς μετά απο τον αντικείμενο */
selector::after {}
2015-10-16 22:16:11 +03:00
/* Σε σωστά σημεία (όχι πολύ ψηλά στην ιεραρχία) ο αστερίσκος μπορείς ν α χρησιμοποιηθεί γ ι α ν α
2015-10-16 22:06:59 +03:00
επιλέξουμε όλα τα αντικείμενα */
* { } /* όλα τα αντικείμενα της σελίδας */
.parent * { } /* όλους τους απόγονους */
.parent > * { } /* όλους τους απόγονους πρώτου επιπέδου */
/* ####################
## Ιδιότητες
#################### */
selector {
/* Ο ι μονάδες μπορούν ν α είναι είτε απόλυτες είτε σχετικές */
/* Σχετικές μονάδες */
width: 50%; /* ποσοστό επί του πλάτους του γονέα */
font-size: 2em; /* πολλαπλασιαστής της αρχικής τιμής του αντικειμένου */
2015-10-16 22:16:11 +03:00
font-size: 2rem; /* ή της τιμής του πρώτου αντικειμένου στην ιεραρχία */
2015-10-16 22:06:59 +03:00
font-size: 2vw; /* πολλαπλαστιαστής του 1% του οπτικού πλάτους */
font-size: 2vh; /* ή τους ύψους */
font-size: 2vmin; /* οποιοδήποτε απο αυτα τα δύο είναι το μικρότερο */
font-size: 2vmax; /* ή το μεγαλύτερο */
/* Απόλυτες μονάδες */
width: 200px; /* pixels */
2015-10-16 22:32:54 +03:00
font-size: 20pt; /* στιγμες */
2015-10-16 22:06:59 +03:00
width: 5cm; /* εκατοστά */
min-width: 50mm; /* χιλιοστά */
max-width: 5in; /* ίντσες */
/* Χρώματα */
color: #F6E ; /* σύντομη δεκαεξαδική μορφή */
color: #FF66EE ; /* δεκαεξαδική μορφή */
color: tomato; /* χρώμα με το όνομα του (συγκεκριμένα χρώματα) */
color: rgb(255, 255, 255); /* τιμή RGB */
color: rgb(10%, 20%, 50%); /* τιμή RGB με ποσοστά */
color: rgba(255, 0, 0, 0.3); /* τιμή RGBA (CSS3) σ σ . 0 < a < 1 * /
color: transparent; /* όπως και το παραπάνω με a = 0 */
color: hsl(0, 100%, 50%); /* τιμή hsl με ποσοστά (CSS 3) */
color: hsla(0, 100%, 50%, 0.3); /* τιμή hsla με ποσοστά και a */
/* Εικόνες μπορούν ν α τοποθετηθούν στον φόντο ενός αντικειμένου */
background-image: url(/img-path/img.jpg);
/* Γραμματοσειρές */
font-family: Arial;
/* εάν η γραμματοσειρα περιέχει κενά */
font-family: "Courier New";
/* εάν η πρώτη γραμματοσειρα δε βρεθεί εγκατεστημένη στο Λειτουργικό Σύστυμα, αυτόματα
επιλέγετε η δεύτερη, κ.κ.ε. */
font-family: "Courier New", Trebuchet, Arial, sans-serif;
}
```
## Χρήση
Αποθηκεύουμε ένα αρχείο CSS με την επέκταση `.css` .
```xml
<!-- Πρέπει ν α συμπεριλάβουμε το αρχείο στην επικεφαλίδα(head) ενος HTML αρχείου.
σ σ . http://stackoverflow.com/questions/8284365 -->
< link rel = 'stylesheet' type = 'text/css' href = 'path/to/style.css' / >
<!-- Μπορούμε ν α το ενσωματώσουμε -->
< style >
a { color: purple; }
< / style >
<!-- Ή απευθείας σε κάποιο αντικείμενο (inline) -->
< div style = "border: 1px solid red;" >
< / div >
```
## Ειδικότητα των κανόνων (Cascading απο το αγγλικό τίτλο Cascading Style Sheets)
Ένα αντικείμενο μπορεί ν α στοχευθεί απο πολλούς κανόνες και μπορεί η ίδια ιδιότητα ν α
περιλαμβάνετε σε πολλούς κανόνες. Σε αυτές της περιπτώσεις υπερισχύει πάντα ο πιο ειδικός
2015-10-16 22:27:30 +03:00
κανόνας και απο αυτούς, αυτός που εμφανίζεται τελευταίος.
2015-10-16 22:06:59 +03:00
```css
/* A */
p.class1[attr='value']
/* B */
p.class1 { }
/* C */
p.class2 { }
/* D */
p { }
/* E */
p { property: value !important; }
```
```xml
< p style = '/*F*/ property:value;' class = 'class1 class2' attr = 'value' / >
```
Η σειρά θα είναι:
2015-10-16 22:27:30 +03:00
* `E` έχει μεγαλύτερο βάρος λόγω του `!important` . Κάλες πρακτικές λένε ν α το αποφεύγουμε.
* `F` επόμενο λόγω του inline κανόνα.
* `A` επόμενο λόγω του το οτι είναι πιο ειδικό. Περιέχει τρεις selectors.
* `C` επόμενο, λόγω του οτι εμφανίζεται μετα το Β και ας έχει την ίδια ειδικότητα.
2015-10-16 22:06:59 +03:00
* `B` επόμενο.
2015-10-16 22:07:49 +03:00
* `D` τελευταίο.
2015-10-16 22:06:59 +03:00
2015-10-16 22:13:41 +03:00
## Συμβατότητα
2015-10-16 22:06:59 +03:00
Τ α περισσότερα απο τα παραπάνω ήδη υποστηρίζονται απο τους γνωστούς φυλλομετρητές. Άλλα θα πρέπει
2015-10-16 22:07:49 +03:00
πάντα ν α ελέγχουμε πρωτου τους χρησιμοποιήσουμε.
2015-10-16 22:06:59 +03:00
## Περισσότερα
2015-10-16 22:13:41 +03:00
* Έλεγχος συμβατότητας, [CanIUse ](http://caniuse.com ).
2015-10-16 22:06:59 +03:00
* CSS Playground [Dabblet ](http://dabblet.com/ ).
* [Mozilla Developer Network's CSS documentation ](https://developer.mozilla.org/en-US/docs/Web/CSS )
* [Codrops' CSS Reference ](http://tympanus.net/codrops/css_reference/ )
## Μελέτη
* [Understanding Style Precedence in CSS: Specificity, Inheritance, and the Cascade ](http://www.vanseodesign.com/css/css-specificity-inheritance-cascaade/ )
* [Selecting elements using attributes ](https://css-tricks.com/almanac/selectors/a/attribute/ )
* [QuirksMode CSS ](http://www.quirksmode.org/css/ )
* [Z-Index - The stacking context ](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Understanding_z_index/The_stacking_context )
* [SASS ](http://sass-lang.com/ ) and [LESS ](http://lesscss.org/ ) for CSS pre-processing
* [CSS-Tricks ](https://css-tricks.com )