सैस - सिंटेक्स

इस अध्याय में, हम SASS के बारे में अध्ययन करेंगे Syntax। SASS दो सिंटैक्स का समर्थन करता हैSCSS तथा Indented syntax

  • SCSS (Sassy CSS)CSS सिंटैक्स का एक एक्सटेंशन है। इसका अर्थ है कि प्रत्येक वैध CSS एक मान्य SCSS भी है। SCSS बड़ी शैलियों को बनाए रखने के लिए बहुत आसान बनाता है और विक्रेता विशिष्ट सिंटैक्स को पहचान सकता है, कई CSS और SCSS फाइलें एक्सटेंशन का उपयोग करती हैं.scss

  • Indented - यह पुराना सिंटैक्स है और कभी-कभी इसे केवल कहा जाता है SASS। सिंटैक्स के इस रूप का उपयोग करते हुए, सीएसएस को स्पष्ट रूप से लिखा जा सकता है। SASS फाइलें एक्सटेंशन का उपयोग करती हैं.sass

SASS इंडेंट सिंटैक्स

SASS इंडेंटेड सिंटैक्स या बस SASS CSS आधारित SCSS सिंटैक्स का विकल्प है।

  • यह बजाय इंडेंटेशन का उपयोग करता है{ तथा } परिसीमन करने के लिए।

  • बयानों को अलग करने के लिए, यह अर्धविराम (;) के बजाय नईलाइनों का उपयोग करता है

  • संपत्ति की घोषणा और चयनकर्ताओं को अपनी लाइन और स्टेटमेंट के भीतर रखा जाना चाहिए{ तथा }पर रखा जाना चाहिए नई लाइन और दांतेदार

उदाहरण के लिए, निम्नलिखित SCSS कोड पर विचार करें -

.myclass {
   color = red;
   font-size = 0.2em;
}

indentedवाक्यविन्यास एक पुराना वाक्यविन्यास है, जिसे नई Sass फ़ाइलों में उपयोग के लिए अनुशंसित नहीं किया जाता है। यदि आप इस फ़ाइल का उपयोग करते हैं, तो यह सीएसएस फ़ाइल में त्रुटि प्रदर्शित करेगा जैसा हमने उपयोग किया है= इसके बजाय गुण और चर सेट करने के लिए।

निम्नलिखित कमांड का उपयोग करके ऊपर दिए गए कोड को संकलित करें -

sass --watch C:\ruby\lib\sass\style.scss:style.css

अगला, उपरोक्त कमांड चलाएं; यह नीचे दिखाए अनुसार style.css फ़ाइल में एक त्रुटि प्रदर्शित करेगा -

Error: Invalid CSS after "  color = red": expected "{", was ";"
      on line 2 of C:\ruby\lib\sass\style17.scss

1:.myclass {
2:   color = red;
3:   font-size = 0.2em;
4:}

सि स स के अंतर

ज्यादातर CSS और SCSS सिंटेक्स पूरी तरह से SASS में काम करते हैं। हालाँकि, कुछ अंतर हैं, जिन्हें निम्नलिखित वर्गों में समझाया गया है -

संपत्ति सिंटैक्स

CSS संपत्तियों को दो तरीकों से घोषित किया जा सकता है -

  • गुणों को सीएसएस के समान घोषित किया जा सकता है लेकिन बिना semicolon(;)

  • colon(:) हर संपत्ति के नाम पर उपसर्ग किया जाएगा।

उदाहरण के लिए, आप इस प्रकार लिख सकते हैं -

.myclass
   :color red
   :font-size 0.2em

उपरोक्त दोनों तरीके (अर्धविराम और संपत्ति के नाम के पूर्व उपनिवेश के बिना गुणों की घोषणा) का उपयोग डिफ़ॉल्ट रूप से किया जा सकता है। हालाँकि, केवल एक गुण सिंटैक्स को निर्दिष्ट करने की अनुमति दी जाती है जब आप उपयोग करते हैं : property_syntax विकल्प।

मल्टीलाइन चयनकर्ता

इंडेंटेड सिंटैक्स में, चयनकर्ताओं को जब भी वे दिखाई देते हैं, उन्हें एक नई पंक्ति में रखा जा सकता है commas

उदाहरण

निम्नलिखित उदाहरण SCSS फ़ाइल में बहुस्तरीय चयनकर्ताओं के उपयोग का वर्णन करता है -

<html>
   <head>
      <title>Multiline Selectors</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css" />
      <link rel = "stylesheet" href = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
      <script src = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
   </head>
   
   <body>
      <h2>Example using Multiline Selectors</h2 >
      <p class = "class1">Welcome to Tutorialspoint!!!</p>
      <p class = "class2">SASS stands for Syntactically Awesome Stylesheet...</p>
   </body>
</html>

इसके बाद, file style.scss बनाएं.Scss एक्सटेंशन पर ध्यान दें ।

style.scss

.class1,
.class2{
   color:red;
}

आप SASS को फाइल देखने के लिए और CSS को अपडेट करने के लिए जब भी SASS फाइल बदल सकते हैं, निम्न कमांड का उपयोग करके बता सकते हैं -

sass --watch C:\ruby\lib\sass\style.scss:style.css

अगला, ऊपर दी गई कमांड को निष्पादित करें, यह style.css फ़ाइल को निम्नलिखित कोड के साथ स्वचालित रूप से बनाएगा -

उत्पन्न की गई शैली । नीचे जैसा दिखाया गया है -

style.css

.class1,
.class2 {
   color: red;
}

उत्पादन

ऊपर दिए गए कोड कैसे काम करते हैं, यह देखने के लिए हम निम्नलिखित कदम उठाते हैं -

  • ऊपर दिए गए html कोड को multiline_selectors .html फ़ाइल में सहेजें ।

  • इस HTML फाइल को ब्राउजर में खोलें, जैसा कि नीचे दिखाया गया है।

टिप्पणियाँ

टिप्पणियाँ एक पूरी लाइन लेती हैं और उनके अंतर्गत आने वाले सभी पाठों को संलग्न करती हैं। वे इंडेंटेड सिंटैक्स में लाइन-आधारित हैं। टिप्पणियों के बारे में अधिक जानकारी के लिए, इस लिंक को देखें ।

@आयात

SASS में @importनिर्देश को उद्धरण के साथ / बिना लिखा जा सकता है। SCSS के विपरीत, उनका उपयोग उद्धरण के साथ किया जाना चाहिए।

उदाहरण के लिए, SCSS में @import निर्देश के रूप में इस्तेमाल किया जा सकता है -

@import "themes/blackforest";
@import "style.sass";

इसे SASS में इस प्रकार लिखा जा सकता है -

@import themes/blackforest
@import fontstyle.sass

मिक्सिन निर्देश

एसएएस जैसे निर्देशों के लिए आशुलिपि का समर्थन करता है @mixin तथा @include। के बजाय@mixin तथा @include आप उपयोग कर सकते हैं = तथा + वर्ण, जिन्हें कम टाइपिंग की आवश्यकता होती है और आपके कोड को सरल और पढ़ने में आसान बनाता है।

उदाहरण के लिए, आप मिक्सिन निर्देश लिख सकते हैं -

=myclass
   font-size: 12px;
p
   +myclass

ऊपर दिया गया कोड समान है -

@mixin myclass
   font-size: 12px;
p
   @include myclass

पदावनत सिंटेक्स

SASS कुछ पुराने वाक्यविन्यास के उपयोग का समर्थन करता है। हालाँकि, SASS में इस सिंटैक्स का उपयोग करना हैnot recommended। यदि आप इस सिंटैक्स का उपयोग करते हैं तो चेतावनी प्रदर्शित की जाएगी और इसे बाद के संस्करणों में हटा दिया जाएगा। कुछ पुराने वाक्यविन्यास निम्नलिखित तालिका में दिखाए गए हैं।

एस। ऑपरेटर और विवरण
1

=

इसका उपयोग इसके बजाय किया गया था: जब SassScript के मानों को चर और गुण सेट करते हैं।

2

||=

इसका उपयोग इसके बजाय किया गया था: जब भी आप किसी चर का डिफ़ॉल्ट मान निर्दिष्ट कर रहे हों।

3

!

$ के बजाय,! चर उपसर्ग के रूप में इस्तेमाल किया गया था। जब $ के बजाय इसका उपयोग किया जाता है तो कार्यक्षमता को नहीं बदला जाएगा।