सैस - त्वरित गाइड

SASS क्या है?

SASS (Syntactically Awesome Stylesheet) एक CSS प्री-प्रोसेसर है, जो CSS के साथ पुनरावृत्ति को कम करने में मदद करता है और समय बचाता है। यह अधिक स्थिर और शक्तिशाली सीएसएस एक्सटेंशन भाषा है जो साफ और संरचनात्मक रूप से एक दस्तावेज़ की शैली का वर्णन करता है।

यह शुरू में द्वारा डिजाइन किया गया था Hampton Catlin और द्वारा विकसित Natalie Weizenbaum 2006 में। बाद में, Weizenbaum तथा Chris Eppstein SassScript के साथ Sass का विस्तार करने के लिए इसके प्रारंभिक संस्करण का उपयोग किया।

SASS का उपयोग क्यों करें?

  • यह एक पूर्व-प्रसंस्करण भाषा है जो सीएसएस के लिए इंडेंटेड सिंटैक्स (इसका अपना सिंटैक्स) प्रदान करती है।

  • यह कुछ विशेषताएं प्रदान करता है, जो स्टाइलशीट बनाने के लिए उपयोग की जाती हैं जो कोड को अधिक कुशलता से लिखने की अनुमति देता है और बनाए रखना आसान होता है।

  • यह सीएसएस का एक सुपर सेट है, जिसका अर्थ है कि इसमें सीएसएस की सभी विशेषताएं हैं और यह एक खुला स्रोत प्री-प्रोसेसर है, जिसे कोडित किया गया है Ruby

  • यह फ्लैट सीएसएस की तुलना में एक अच्छी, संरचित प्रारूप में दस्तावेज़ शैली प्रदान करता है। इसमें री-यूजेबल मेथड्स, लॉजिक स्टेटमेंट्स और कुछ बिल्ट-इन फंक्शन्स जैसे कलर मैनिपुलेशन, मैथमेटिक्स और पैरामीटर लिस्ट का इस्तेमाल किया गया है।

SASS की विशेषताएं

  • यह सीएसएस के संस्करणों के साथ अधिक स्थिर, शक्तिशाली और संगत है।

  • यह CSS का एक सुपर सेट है और जावास्क्रिप्ट पर आधारित है।

  • इसे CSS के लिए सिंथैटिक शुगर के रूप में जाना जाता है, जिसका अर्थ है कि यह उपयोगकर्ता के लिए चीजों को अधिक स्पष्ट रूप से पढ़ने या व्यक्त करने का आसान तरीका है।

  • यह अपने स्वयं के सिंटैक्स का उपयोग करता है और पठनीय सीएसएस के संकलन करता है।

  • आप आसानी से कम समय में कम कोड में CSS लिख सकते हैं।

  • यह एक ओपन सोर्स प्री-प्रोसेसर है, जिसकी व्याख्या सीएसएस में की जाती है।

स स के लाभ

  • यह एक प्रोग्रामिंग निर्माण में साफ सीएसएस लिखने की अनुमति देता है।

  • यह जल्दी से CSS लिखने में मदद करता है।

  • यह CSS का एक सुपरसेट है, जो डिजाइनरों और डेवलपर्स को अधिक कुशलतापूर्वक और तेज़ी से काम करने में मदद करता है।

  • जैसा कि एसएसएस सीएसएस के सभी संस्करणों के साथ संगत है, हम किसी भी उपलब्ध सीएसएस पुस्तकालयों का उपयोग कर सकते हैं।

  • नेस्टेड सिंटैक्स और उपयोगी कार्यों जैसे कि रंग हेरफेर, गणित और अन्य मूल्यों का उपयोग करना संभव है।

SASS का नुकसान

  • एक डेवलपर को इस प्री-प्रोसेसर में मौजूद नई सुविधाओं को सीखने में समय लगता है।

  • यदि कई लोग एक ही साइट पर काम कर रहे हैं, तो उसी प्रीप्रोसेसर का उपयोग करना चाहिए। कुछ लोग Sass का उपयोग करते हैं और कुछ लोग सीधे फाइलों को संपादित करने के लिए CSS का उपयोग करते हैं। इसलिए, साइट पर काम करना मुश्किल हो जाता है।

  • ब्राउज़र के अंतर्निहित तत्व निरीक्षक के लाभ खोने की संभावना है।

इस अध्याय में, हम रूबी को स्थापित करने के लिए चरण-दर-चरण प्रक्रिया सीखेंगे, जिसका उपयोग एसएएस फाइलों को निष्पादित करने के लिए किया जाता है।

SASS के लिए सिस्टम आवश्यकताएँ

  • Operating System - क्रॉस-प्लेटफॉर्म

  • Browser Support - IE (इंटरनेट एक्सप्लोरर 8+), फ़ायरफ़ॉक्स, गूगल क्रोम, सफारी, ओपेरा

  • Programming Language - रूबी

रूबी की स्थापना

Step 1 - लिंक खोलें https://www.ruby-lang.org/en/downloads/, आप नीचे दिखाए गए अनुसार एक स्क्रीन देखेंगे -

ज़िप फ़ाइल का वर्तमान स्थिर संस्करण डाउनलोड करें ।

Step 2 - अगला, इंस्टॉल करने के लिए सेटअप चलाएं Ruby सिस्टम पर।

Step 3- इसके बाद, रत्न आदेश के साथ काम करने के लिए अपने पथ उपयोगकर्ता चर और सिस्टम चर के लिए रूबी बिन फ़ोल्डर जोड़ें ।

Path User Variable -

  • राइट क्लिक करें My Computer आइकन।

  • चुनते हैं Properties

  • इसके बाद क्लिक करें Advanced टैब और क्लिक करें Environment Variables

में पर्यावरण चर खिड़की, डबल क्लिक करें पथ के रूप में नीचे दिए गए स्क्रीनशॉट में दिखाया गया -

आपको एडिट यूजर वैरिएबल बॉक्स मिलेगा जैसा कि दिखाया गया है। के रूप में चर मान क्षेत्र में रूबी बिन फ़ोल्डर पथ जोड़ेंC:\Ruby\bin। यदि पथ अन्य फ़ाइलों के लिए पहले से ही सेट है, तो उसके बाद अर्धविराम लगाएं और नीचे दिखाए गए अनुसार रूबी फ़ोल्डर पथ जोड़ें।

दबाएं OK बटन।

System Variable -

  • दबाएं New बटन।

इसके बाद द New System Variable ब्लॉक को नीचे दिखाए अनुसार प्रदर्शित किया जाता है।

  • दर्ज RubyOptमें चर नाम क्षेत्र औरrubygemsमें चर मूल्य क्षेत्र। चर नाम और मान लिखने के बाद , क्लिक करेंOK बटन।

Step 4 - अपने सिस्टम में कमांड प्रॉम्प्ट खोलें और निम्नलिखित लाइन दर्ज करें -

gem install sass

Step 5 - इसके बाद, आप SASS को सफलतापूर्वक स्थापित करने के बाद निम्न स्क्रीन देखेंगे।

उदाहरण

निम्नलिखित SASS का एक सरल उदाहरण है।

<html>
   <head>
      <title> Import example of sass</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Simple Example</h1>
      <h3>Welcome to TutorialsPoint</h3>
   </body>
</html>

अब, हम file.scss के रूप में फाइल बनाएंगे , जो कि CSS के समान है और केवल एक अंतर यह है कि इसे .scss एक्सटेंशन के साथ सहेजा जाएगा। दोनों .htm और .scss फ़ाइलों को फ़ोल्डर के अंदर बनाया जाना चाहिएruby। आप अपने .scss फ़ाइल को फ़ोल्डर में सहेज सकते हैंruby\lib\sass\ (इस प्रक्रिया से पहले, के रूप में एक फ़ोल्डर बनाएँ sass में)

h1{
   color: #AF80ED;
}

h3{
   color: #DE5E85;
}

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

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

जब आप ऊपर कमांड चलाते हैं, तो यह अपने आप style.css फ़ाइल बना देगा । जब भी आप SCSS फ़ाइल बदलते हैं, तो style.css फ़ाइल अपने आप अपडेट हो जाएगी।

Style.css जब आप ऊपर दिए गए आदेश चला फ़ाइल निम्न कोड होगा -

style.css

h1 {
   color: #AF80ED;
}
h3 {
   color: #DE5E85;
}

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

  • ऊपर दिए गए कोड को सेव करें hello.html फ़ाइल।

  • इस HTML फाइल को ब्राउजर में खोलें।

इस अध्याय में, हम 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

!

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

SASS अधिक शक्तिशाली और स्थिर है जो CSS के विस्तार का उपयोग करके मूल भाषा को शक्ति प्रदान करता है। आप तीन अलग-अलग तरीकों से SASS का उपयोग कर सकते हैं -

  • कमांड लाइन टूल के रूप में
  • रूबी मॉड्यूल के रूप में
  • रैक सक्षम ढांचे के लिए एक प्लगइन के रूप में

यदि आप विंडोज़ पर SASS का उपयोग कर रहे हैं, तो आपको इंस्टॉल करने की आवश्यकता है Rubyप्रथम। रूबी को स्थापित करने के बारे में अधिक जानकारी के लिए, SASS स्थापना अध्याय देखें ।

निम्न तालिका आज्ञाओं को दिखाती है, जिन्हें SASS कोड निष्पादित करने के लिए उपयोग किया जाता है -

एस। कमांड और विवरण
1

sass input.scss output.css

इसका उपयोग कमांड लाइन से SASS कोड को चलाने के लिए किया जाता है।

2

sass --watch input.scss:output.css

यह SASS को फ़ाइल देखने के लिए सूचित करता है और जब भी SASS फ़ाइल बदलता है तो CSS को अपडेट करता है।

3

sass --watch app/sass:public/stylesheets

इसका उपयोग संपूर्ण निर्देशिका को देखने के लिए किया जाता है, यदि SASS में एक निर्देशिका में कई फाइलें होती हैं।

रैक / रेल / मार्क प्लगिन

Rackएक वेब सर्वर इंटरफ़ेस है, जिसका उपयोग रूबी में वेब एप्लिकेशन विकसित करने के लिए किया जाता है। रैक के बारे में जानकारी के लिए, बस इस लिंक पर जाएँ ।

आप SASS को इसमें सक्षम कर सकते हैं Rails 3 संस्करण का उपयोग कर environment.rb के तहत मौजूद फाइल configफ़ोल्डर। निम्नलिखित कोड का उपयोग करके रेल 3 के लिए SASS सक्षम करें -

config.gem "sass"

आप रेलिंग 3 के लिए निम्नलिखित पंक्ति का उपयोग कर सकते हैं (और इसके बाद के संस्करण के रूप में), -

gem "sass"

Railsएक ओपन-सोर्स वेब फ्रेमवर्क है जो उपयोगकर्ता इंटरफ़ेस प्रदर्शित करने के लिए JSON, HTML, CSS और जावास्क्रिप्ट जैसे वेब मानकों का उपयोग करता है। रेल के साथ काम करने के लिए, आपको रूबी और ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग का बुनियादी ज्ञान होना चाहिए। रेल ढांचे के बारे में अधिक जानें यहां ।

यदि आप SASS को सक्षम करना चाहते हैं Rack आवेदन, निम्नलिखित लाइनों को जोड़ने के लिए config.ru फ़ाइल, जो ऐप की रूट डायरेक्टरी में मौजूद है -

require 'sass/plugin/rack'
use Sass::Plugin::Rack

Merbएक वेब एप्लीकेशन फ्रेमवर्क है, जो रेल्स को गति और प्रतिरूपकता प्रदान करता है। Merb के बारे में अधिक जानने के लिए, बस इस लिंक को खोलें ।

आप SASS को सक्षम कर सकते हैं Merb निम्नलिखित पंक्ति को जोड़कर config/dependencies.rb फ़ाइल -

dependency "merb-haml"

कैशिंग

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

विकल्प

आप में विकल्प सेट कर सकते environment.rb रेल की फ़ाइल या config.ru निम्न पंक्ति का उपयोग करके रैक आवेदन की फ़ाइल -

Sass::Plugin.options[:style] = :compact

आप निम्न लाइन का उपयोग करके Merb की init.rb फ़ाइल में विकल्प भी सेट कर सकते हैं -

Merb::Plugin.config[:sass][:style] = :compact

नीचे दिए गए तालिका में वर्णित के रूप में एसएएसएस और एससीएसएस के साथ कुछ विकल्प उपलब्ध हैं -

एस। विकल्प और विवरण
1

:style

यह आउटपुट की शैली प्रदर्शित करता है।

2

:syntax

आप के लिए इंडेंट सिंटैक्स का उपयोग कर सकते हैं सास के लिए और सीएसएस विस्तार वाक्य रचना एससीएसएस

3

:property_syntax

यह गुणों का उपयोग करने के लिए इंडेंटेड सिंटैक्स का उपयोग करता है। यदि यह सही नहीं है, तो यह एक त्रुटि फेंक देगा। उदाहरण के लिए, "पृष्ठभूमि: # F5F5F5" पर विचार करें, जिसमें पृष्ठभूमि एक संपत्ति का नाम है और # F5F5F5 इसका संपत्ति मूल्य है। संपत्ति के नाम के बाद आपको कोलन का उपयोग करना चाहिए।

4

:cache

यह SASS फ़ाइलों के संकलन को गति देता है। यह डिफ़ॉल्ट रूप से सही पर सेट है।

5

:read_cache

यदि कैश सेट नहीं है और read_cache सेट है तो यह केवल SASS फाइलें पढ़ता है।

6

:cache_store

इसका उपयोग कैश्ड परिणाम को Sass :: CacheStores :: Base के उदाहरण पर सेट करके स्टोर करने और एक्सेस करने के लिए किया जा सकता है ।

7

:never_update

यदि टेम्पलेट फ़ाइलें बदलती हैं तो इसे सीएसएस फ़ाइल को कभी भी अपडेट नहीं करना चाहिए। डिफ़ॉल्ट रूप से यह गलत पर सेट होता है।

8

:always_update

जब भी टेम्प्लेट फाइल बदलती है तो उसे CSS फाइल को अपडेट करना चाहिए।

9

:always_check

जब भी सर्वर शुरू होता है तो उसे अपडेट की जांच करनी चाहिए। यदि SASS टेम्पलेट फ़ाइल में कोई अद्यतन है, तो यह CSS फ़ाइल को फिर से लिखना और अधिलेखित कर देगा।

10

:poll

यह Sass :: Plugin :: Compiler # घड़ी (जो CSS फाइलों के टेम्प्लेट और अपडेशन देखता है) को सही पर सेट करके मतदान बैकएंड का उपयोग करता है।

1 1

:full_exception

जब भी उत्पन्न CSS फ़ाइल में SASS कोड में कोई अपवाद होता है, तो यह त्रुटि विवरण प्रदर्शित करता है। यह एक लाइन नंबर प्रदर्शित करता है जहां सीएसएस फ़ाइल में स्रोत के साथ एक त्रुटि हुई।

12

:template_location

यह एप्लिकेशन में टेम्प्लेट डायरेक्टरी के लिए पथ प्रदान करता है।

13

:css_location

यह आवेदन में सीएसएस स्टाइलशीट के लिए पथ प्रदान करता है।

14

:unix_newlines

यह यूनिक्स शैली को नया सेट प्रदान करता है, जब फाइलों को सही पर सेट करके लिखता है।

15

:filename

यह फ़ाइल नाम का प्रदर्शन किया जा रहा है और रिपोर्टिंग त्रुटियों के लिए उपयोग किया जाता है।

16

:line

यह SASS टेम्पलेट की पहली पंक्ति को निर्दिष्ट करता है और त्रुटियों के लिए लाइन संख्या प्रदर्शित करता है।

17

:load_paths

इसका उपयोग SASS टेम्पलेट के लिए रास्तों को लोड करने के लिए किया जाता है जो @import निर्देश का उपयोग करके शामिल किए जाते हैं ।

18

:filesystem_importer

इसका उपयोग फ़ाइल सिस्टम से फ़ाइलों को आयात करने के लिए किया जाता है जो Sass :: Importers :: Base सब क्लास का उपयोग करता है ताकि स्ट्रिंग लोड पथों को संभाल सकें।

19

:sourcemap

यह स्रोत मानचित्र बनाता है जो ब्राउज़र को SASS शैलियों को खोजने का निर्देश देता है। यह तीन मूल्यों का उपयोग करता है -

  • :auto- इसमें सापेक्ष यूआरआई शामिल हैं। यदि कोई रिश्तेदार यूआरआई नहीं है, तो "फाइल:" यूआरआई का उपयोग करता है।

  • :file - यह "फ़ाइल:" यूआरआई का उपयोग करता है, जो स्थानीय रूप से काम करते हैं, रिमोट सर्वर पर नहीं।

  • :inline - इसमें सोर्स मैप में सोर्स टेक्स्ट होता है जिसका इस्तेमाल बड़े सोर्स मैप फाइल बनाने के लिए किया जाता है।

20

:line_numbers

यह सीएसएस फ़ाइल में रिपोर्ट की गई त्रुटियों के लिए लाइन नंबर को सही पर सेट करके प्रदर्शित करता है।

21

:trace_selectors

यह सही होने पर आयातकों और मिश्रणों के चयनकर्ताओं का पता लगाने में मदद करता है।

22

:debug_info

यह SASS फ़ाइल की डिबग जानकारी लाइन नंबर और फ़ाइल का उपयोग करके प्रदान करता है जब यह सही पर सेट होता है।

23

:custom

यह अलग-अलग अनुप्रयोगों में एसएएस कार्यों के लिए डेटा उपलब्ध कराता है।

24

:quiet

यह चेतावनियों को सत्य पर सेट करके उसे निष्क्रिय कर देता है।

सिंटेक्स चयन

आप SASS कमांड लाइन टूल का उपयोग करके SASS टेम्पलेट में कौन से वाक्य रचना का उपयोग कर रहे हैं, यह निर्धारित कर सकते हैं। डिफ़ॉल्ट रूप से, SASS इंडेंट सिंटैक्स का उपयोग करता है जो CSS आधारित SCSS सिंटैक्स का विकल्प है। आप SCSS कमांड लाइन प्रोग्राम का उपयोग कर सकते हैं, जो SASS प्रोग्राम के समान है, लेकिन डिफ़ॉल्ट रूप से, यह सिंटैक्स को SCSS मानता है।

एन्कोडिंग

SASS निम्नलिखित सीएसएस विशिष्टताओं को निर्दिष्ट करके स्टाइलशीट के चरित्र एन्कोडिंग का उपयोग करता है -

  • सबसे पहले, यह यूनिकोड बाइट, अगले @charset घोषणा और फिर रूबी स्ट्रिंग एन्कोडिंग के लिए जाँच करता है ।

  • अगला, यदि कुछ भी सेट नहीं है, तो यह UTF-8 के रूप में चारसेट एन्कोडिंग को मानता है ।

  • स्पष्ट रूप से @charset घोषणा का उपयोग करके वर्ण एन्कोडिंग निर्धारित करें । स्टाइलशीट की शुरुआत में बस "@charset एन्कोडिंग नाम" का उपयोग करें और SASS मान लेगा कि यह दिया गया वर्ण एन्कोडिंग है।

  • यदि SASS के आउटपुट फ़ाइल में गैर-ASCII वर्ण हैं, तो यह @charset घोषणा का उपयोग करेगा ।

इस अध्याय में, हम इस बारे में अध्ययन करेंगे CSS Extensions। CSS एक्सटेंशन का उपयोग वेब पेजों की कार्यक्षमता बढ़ाने के लिए किया जा सकता है। निम्न तालिका SASS में प्रयुक्त सीएसएस एक्सटेंशन में से कुछ को सूचीबद्ध करती है -

एस। सीएसएस एक्सटेंशन और विवरण
1 नेस्टेड नियम

यह एक दूसरे के भीतर कई सीएसएस नियमों के संयोजन का एक तरीका है।

2 जनक चयनकर्ता: और

यह माता-पिता के चयनकर्ता के चयन की प्रक्रिया है & चरित्र।

3 नेस्टेड गुण

यह अन्य गुणों में गुणों के घोंसले के शिकार की अनुमति देता है जो दूसरे संबंधित कोड के समूह की ओर जाता है।

4 प्लेसहोल्डर चयनकर्ता

Sass , @extend निर्देश का उपयोग करके वर्ग या आईडी चयनकर्ता का उपयोग करके प्लेसहोल्डर चयनकर्ता का समर्थन करता है ।

इस अध्याय में, हम Sass के बारे में अध्ययन करेंगे Comments। टिप्पणियां गैर-निष्पादन योग्य कथन हैं, जिन्हें स्रोत कोड में रखा गया है। टिप्पणियाँ सोर्स कोड को समझने में आसान बनाती हैं। SASS दो प्रकार की टिप्पणियों का समर्थन करता है।

  • Multiline comments- ये / * और * / का उपयोग करके लिखे गए हैं। सीएसएस आउटपुट में बहुस्तरीय टिप्पणियां संरक्षित हैं।

  • Single line comments - ये प्रयोग करके लिखे गए हैं //टिप्पणियों के बाद। सीएसएस आउटपुट में सिंगल लाइन टिप्पणियां संरक्षित नहीं हैं।

उदाहरण

निम्नलिखित उदाहरण SCSS फ़ाइल में टिप्पणियों के उपयोग को दर्शाता है -

<html>
   <head>
      <title>SASS comments</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Welcome to TutorialsPoint</h1>
      <a href = "http://www.tutorialspoint.com/">TutorialsPoint</a>
   </body>
</html>

इसके बाद, file style.scss बनाएं

style.scss

/* This comment is
 * more than one line long
 * since it uses the CSS comment syntax,
 * it will appear in the CSS output. */
body { color: black; }

// These comments are in single line
// They will not appear in the CSS output,
// since they use the single-line comment syntax.
a { color: blue; }

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

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

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

style.css

/* This comment is
 * more than one line long
 * since it uses the CSS comment syntax,
 * it will appear in the CSS output. */
body {
   color: black; }

a {
   color: blue; }

उत्पादन

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

  • ऊपर दिए गए HTML कोड को सेव करें sass_comments.html फ़ाइल।

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

बहुस्तरीय टिप्पणियों के भीतर प्रक्षेप के बारे में अध्ययन करने के लिए, इस लिंक पर क्लिक करें ।

सास - बहुभाषी टिप्पणियों में प्रक्षेप

विवरण

बहुस्तरीय टिप्पणियों के भीतर प्रक्षेप परिणामस्वरूप सीएसएस में हल किए जाते हैं। आप घुंघराले ब्रेसिज़ के भीतर चर या संपत्ति के नाम निर्दिष्ट कर सकते हैं।

वाक्य - विन्यास

$var : "value";
/* multiline comments #{$var} */

उदाहरण

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

<html>
   <head>
      <title>SASS comments</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css"/>
   </head>

   <body>
      <h1>Welcome to TutorialsPoint</h1>
      <p>This is an example for Interpolation in SASS.</p>
   </body>
</html>

इसके बाद, file style.scss बनाएं

style.css

$version: "7.8";
/* Framework version for the generated CSS is #{$version}. */

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

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

अगला, उपरोक्त कमांड निष्पादित करें; यह निम्नलिखित कोड के साथ अपने आप style.css फ़ाइल बनाएगा

style.css

/* Framework version for the generated CSS is 7.8. */

उत्पादन

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

  • ऊपर दिए गए HTML कोड को सेव करें sass_comments_interpolation.htm फ़ाइल।

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

SASS SassScript के रूप में ज्ञात एक्सटेंशन के एक छोटे से सेट का उपयोग करता है जिसे संपत्ति के मूल्यों से चर की गणना करने के लिए SASS दस्तावेजों में शामिल किया जा सकता है और चर, अंकगणित और अन्य कार्यों के गुणों का उपयोग करता है। SassScript का उपयोग चयनकर्ताओं और संपत्ति के नामों के साथ भी किया जा सकता है, जबकि मिक्सिंस का उपयोग करते हुए (मिक्सिन्स पूरे स्टाइलशीट में सीएसएस शैलियों को फिर से उपयोग करने की अनुमति देता है)।

निम्न तालिका SASS में प्रयुक्त सीएसएस एक्सटेंशन में से कुछ को सूचीबद्ध करती है -

एस। सीएसएस एक्सटेंशन और विवरण
1 इंटरएक्टिव शेल

यह कमांड लाइन का उपयोग करके SassScript अभिव्यक्ति का मूल्यांकन करता है।

2 चर

यह संख्यात्मक मान, वर्ण या स्मृति पते जैसे डेटा का प्रतिनिधित्व करता है।

3 जानकारी का प्रकार

यह हर डेटा ऑब्जेक्ट के लिए डेटा प्रकार घोषित करता है।

4 संचालन

यह संख्या, रंग, स्ट्रिंग, बूलियन और सूची संचालन जैसे संचालन प्रदान करता है।

5 कोष्टक

यह उन संकेतों की जोड़ी है जो आमतौर पर गोल कोष्ठक () या वर्ग कोष्ठक [] द्वारा चिह्नित होते हैं।

6 कार्यों

यह कुछ खोजशब्द तर्क प्रदान करके कार्यों के उपयोग के लिए समर्थन करता है।

7 प्रक्षेप

यह SassScript चर और संपत्ति के नाम प्रदान करता है #{ } वाक्य - विन्यास।

8 और SassScript में

यह अन्य गुणों में गुणों के घोंसले के शिकार की अनुमति देता है जो दूसरे संबंधित कोड के समूह की ओर जाता है।

9 चर दोष

यह अन्य गुणों में गुणों के घोंसले के शिकार की अनुमति देता है जो दूसरे संबंधित कोड के समूह की ओर जाता है।

निम्न तालिका उन सभी नियमों और निर्देशों को सूचीबद्ध करती है, जिन्हें आप SASS में उपयोग कर सकते हैं।

एस। निर्देश और विवरण
1 @आयात

यह SASS या SCSS फ़ाइलों को आयात करता है, यह सीधे आयात करने के लिए फ़ाइल नाम लेता है।

2 @media

यह विभिन्न मीडिया प्रकारों के लिए शैली नियम निर्धारित करता है।

3 @extend

@extend निर्देश का उपयोग चयनकर्ताओं के बीच नियमों और संबंधों को साझा करने के लिए किया जाता है।

4 @-जड़ में

@ एट-रूट निर्देश नेस्टेड नियमों का एक संग्रह है, जो दस्तावेज़ की जड़ में स्टाइल ब्लॉक बनाने में सक्षम है।

5 @debug

@debug निर्देश त्रुटियों का पता लगाता है और मानक त्रुटि आउटपुट स्ट्रीम में SassScript अभिव्यक्ति मान प्रदर्शित करता है।

6 @warn

@warn निर्देश का उपयोग समस्या के बारे में सावधानी बरतने के लिए किया जाता है; यह SassScript अभिव्यक्ति मान को मानक त्रुटि आउटपुट स्ट्रीम में प्रदर्शित करता है।

7 @error

@err निर्देश SassScript अभिव्यक्ति मान को घातक त्रुटि के रूप में प्रदर्शित करता है।

इस अध्याय में, हम इस बारे में अध्ययन करेंगे Control Directives & Expressions। कुछ शर्तों के आधार पर स्टाइलिंग या एक ही शैली को कई बार विविधताओं के साथ लागू करने से नियंत्रण निर्देशों और अभिव्यक्तियों का उपयोग करके पूरा किया जा सकता है, जो SassScript द्वारा समर्थित हैं। ये नियंत्रण निर्देश उन्नत विकल्प हैं जो मुख्य रूप से मिश्रणों में उपयोग किए जाते हैं। उन्हें काफी लचीलेपन की आवश्यकता है, क्योंकि वे कम्पास पुस्तकालयों का एक हिस्सा हैं।

निम्न तालिका SASS में प्रयुक्त नियंत्रण निर्देशों और अभिव्यक्तियों को सूचीबद्ध करती है -

एस। नियंत्रण निर्देश और अभिव्यक्ति विवरण के साथ
1 अगर()

स्थिति के आधार पर, यदि () फ़ंक्शन दो संभावित परिणामों से केवल एक परिणाम देता है।

2 @अगर

@If निर्देश SassScript भाव को स्वीकार करता है और एकत्रित शैलियों का उपयोग करता है जब भी अभिव्यक्ति का परिणाम के अलावा और कुछ है झूठी या अशक्त

3 @के लिये

@For निर्देश आप एक पाश में शैलियों उत्पन्न करने के लिए अनुमति देता है।

4 @से प्रत्येक

में @each निर्देश, एक चर परिभाषित जो एक सूची में प्रत्येक आइटम का मूल्य होता है।

5 @जबकि

यह SassScript एक्सप्रेशन लेता है और जब तक यह कथन गलत तरीके से नेस्टेड स्टाइल को आउटपुट नहीं करता है, तब तक स्टेटमेंट का मूल्यांकन नहीं किया जाता है।

मिक्सिन शैलियों का एक समूह बनाने की अनुमति देते हैं, जो गैर-शब्दार्थ वर्गों के मनोरंजन की आवश्यकता के बिना आपकी स्टाइलशीट में पुन: प्रयोज्य हैं। CSS में, मिश्रण कई मान या मापदंडों और कॉल फ़ंक्शन को स्टोर कर सकते हैं; यह दोहराए जाने वाले कोड लिखने से बचने में मदद करता है। मिक्सिनर नाम अंडरस्कोर और हाइफ़न इंटरचेंज का उपयोग कर सकते हैं। मिक्सिंस में मौजूद निर्देश निम्नलिखित हैं -

एस। निर्देश और विवरण
1 एक मिश्रण को परिभाषित करना

@ मिक्सिन निर्देश का उपयोग मिक्सिन को परिभाषित करने के लिए किया जाता है।

2 जिसमें एक मिक्सिन भी शामिल है

दस्तावेज़ में मिश्रण को शामिल करने के लिए @include निर्देश का उपयोग किया जाता है।

3 बहस

SassScript मूल्यों को मिक्सिन्स में तर्क के रूप में लिया जा सकता है, जो मिक्सिन को शामिल करने और मिक्सिन के भीतर परिवर्तनशील के रूप में उपलब्ध होने पर दिया जाता है।

4 सामग्री ब्लॉक को एक मिश्रण में पास करना

शैलियों के ब्लॉक को मिक्सिन में पारित किया जाता है।

इस अध्याय में, हम इस बारे में अध्ययन करेंगे Function Directives। एसएएसएस में, आप अपना स्वयं का फ़ंक्शन बना सकते हैं और उन्हें अपने स्क्रिप्ट संदर्भ में उपयोग कर सकते हैं या किसी भी मूल्य के साथ उपयोग किया जा सकता है। फ़ंक्शन नाम का उपयोग करके और किसी भी पैरामीटर के साथ कार्य कहा जाता है।

उदाहरण

निम्न उदाहरण SCSS फ़ाइल में फ़ंक्शन निर्देश का उपयोग दर्शाता है -

function_directive.htm

<html>
   <head>
      <title>Nested Rules</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>
      <div class = "container" id = "set_width">
         <h2>Example for Function directives</h2>
         <p>SASS stands for Syntactically Awesome Stylesheet. </p>
      </div>
   </body>
</html>

इसके बाद, file style.scss बनाएं

style.scss

$first-width: 5px;
$second-width: 5px;

@function adjust_width($n) {
   @return $n * $first-width + ($n - 1) * $second-width;
}

#set_width { padding-left: adjust_width(10); }

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

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

अगला, उपरोक्त कमांड निष्पादित करें; यह निम्नलिखित कोड के साथ अपने आप style.css फ़ाइल बनाएगा -

style.css

#set_width {
   padding-left: 95px; 
}

उत्पादन

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

  • ऊपर दिए गए HTML कोड को सेव करें function_directive.html फ़ाइल।

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

आउटपुट में, आप देख सकते हैं कि लेफ्ट-पेडिंग लागू किया जा रहा है।

मिश्रण की तरह, फ़ंक्शन वैश्विक रूप से परिभाषित चर तक भी पहुंच सकता है और मापदंडों को भी स्वीकार कर सकता है। आपको उपयोग करके फ़ंक्शन के लिए रिटर्न मान को कॉल करना चाहिए@return। हम कीवर्ड मापदंडों का उपयोग करके एसएएसएएस-परिभाषित कार्यों को कॉल कर सकते हैं।

उपरोक्त फ़ंक्शन को नीचे दिखाए अनुसार कॉल करें।

#set_width { padding-left: adjust_width($n: 10); }

नामकरण की परंपरा

नामकरण संघर्षों से बचने के लिए फ़ंक्शन नामों को उपसर्ग किया जा सकता है ताकि उन्हें आसानी से विभेदित किया जा सके। मिश्रणों की तरह, परिवर्तनीय तर्क भी उपयोगकर्ता द्वारा परिभाषित कार्यों द्वारा समर्थित हैं। फ़ंक्शंस और अन्य एसएएस पहचानकर्ता अंडरस्कोर (_) और हाइफ़ेंस (-) का उपयोग कर सकते हैं।

उदाहरण के लिए, यदि कोई फ़ंक्शन के रूप में परिभाषित किया गया है adjust_width, यह के रूप में इस्तेमाल किया जा सकता है adjust-width, और इसके विपरीत।

इस अध्याय में, हम इस बारे में अध्ययन करेंगे SASS Output Style। CSS फ़ाइल जिसे SASS जेनरेट करता है, उसमें डिफ़ॉल्ट CSS शैली होती है, जो दस्तावेज़ की संरचना को दर्शाती है। डिफ़ॉल्ट सीएसएस स्टाइलिंग अच्छी है लेकिन सभी स्थितियों के लिए उपयुक्त नहीं हो सकती है; दूसरी ओर, SASS कई अन्य शैलियों का समर्थन करता है।

यह निम्नलिखित विभिन्न आउटपुट शैलियों का समर्थन करता है -

: नेस्ट

नेस्टेड स्टाइल SASS की डिफ़ॉल्ट स्टाइलिंग है। स्टाइल का यह तरीका बहुत उपयोगी है जब आप बड़ी सीएसएस फाइलों के साथ काम कर रहे हैं। यह फ़ाइल की संरचना को अधिक पठनीय बनाता है और इसे आसानी से समझा जा सकता है। प्रत्येक संपत्ति अपनी लाइन लेती है और प्रत्येक नियम का इंडेंटेशन इस बात पर आधारित होता है कि वह कितनी गहराई से नेस्टेड है।

उदाहरण के लिए, हम SASS फ़ाइल में कोड को नीचे दिखाए अनुसार बना सकते हैं -

#first {
   background-color: #00FFFF;
   color: #C0C0C0; 
}

#first p {
   width: 10em; 
}

.highlight {
   text-decoration: underline;
   font-size: 5em;
   background-color: #FFFF00; 
}

: विस्तार

सीएसएस स्टाइल के विस्तारित प्रकार में प्रत्येक संपत्ति और नियम की अपनी लाइन है। नेस्टेड सीएसएस शैली की तुलना में यह अधिक स्थान लेता है। नियम अनुभाग में गुण होते हैं, जो सभी नियमों के भीतर होते हैं, जबकि नियम किसी इंडेंटेशन का पालन नहीं करते हैं।

उदाहरण के लिए, हम नीचे दिखाए गए अनुसार SASS फ़ाइल में कोड का विस्तार कर सकते हैं -

#first {
   background-color: #00FFFF;
   color: #C0C0C0;
}

#first p {
   width: 10em;
}

.highlight {
   text-decoration: underline;
   font-size: 5em;
   background-color: #FFFF00;
}

: कॉम्पैक्ट

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

उदाहरण के लिए, हम नीचे दिखाए गए अनुसार SASS फ़ाइल में कोड को कॉम्पैक्ट कर सकते हैं -

#first { 
   background-color: #00FFFF; color: #C0C0C0; 
}

#first p { 
   width: 10em; 
}

.highlight { 
   text-decoration: underline; font-size: 5em; background-color: #FFFF00; 
}

:दबा हुआ

संपीड़ित सीएसएस शैली ऊपर चर्चा की गई अन्य सभी शैलियों की तुलना में कम से कम स्थान लेती है। यह व्हाट्सएप को केवल चयनकर्ताओं को अलग करने और फाइल के अंत में न्यूलाइन प्रदान करता है। स्टाइल करने का यह तरीका भ्रमित करने वाला है और आसानी से पढ़ने योग्य नहीं है।

उदाहरण के लिए, हम नीचे दिखाए गए अनुसार SASS फ़ाइल में कोड को संपीड़ित कर सकते हैं -

#first { 
   background-color:#00FFFF;color:#C0C0C0
} 

#first p { 
   width:10em 
} 

.highlight { 
   text-decoration:underline;font-size:5em;background-color:#FFFF00 
}

उपयोगकर्ताओं के लिए विभिन्न प्रकार की सुविधाएँ और अनुकूलन प्रदान करने के लिए आप SASS की कार्यक्षमता का विस्तार कर सकते हैं। इन सुविधाओं का उपयोग करने के लिए, उपयोगकर्ता को रूबी का ज्ञान होना चाहिए।

कस्टम SASS फ़ंक्शंस को परिभाषित करना

रूबी एपीआई का उपयोग करते समय आप अपने स्वयं के कार्यों को परिभाषित कर सकते हैं। आप निम्न कोड में दिखाए गए अनुसार अपने रूबी कार्यों को रूबी विधियों में जोड़ सकते हैं -

module Sass::Script::Functions
   def reverse(string)
      assert_type string, :String
      Sass::Script::Value::String.new(string.value.reverse)
   end
   declare :reverse, [:string]
end

कोड में आप देख सकते हैं, फ़ंक्शन, घोषित करता है, फ़ंक्शन के लिए तर्क नामों को निर्दिष्ट करता है। यदि यह विफल रहता है तो यह फ़ंक्शन के काम करने पर भी किसी भी तर्क को स्वीकार नहीं करेगा और यह मनमाने ढंग से कीवर्ड तर्क भी लेता है। आप मूल्य अभिगमकर्ता का उपयोग करके और आरजीबी, लाल, हरे या नीले रंग का उपयोग करके रंगीन वस्तुओं को प्राप्त कर सकते हैं ।

कैश स्टोर

एसएएस ने पार्स किए गए दस्तावेजों का कैश संग्रहीत किया है, जिन्हें फिर से पार्स किए बिना पुन: उपयोग किया जा सकता है। SASS का उपयोग करता है:cache_locationफ़ाइल सिस्टम पर कैश फ़ाइलों को लिखने के लिए। यह SASS फ़ाइलों का तेजी से संकलन करता है और यदि आप कैश्ड फ़ाइलों को हटाते हैं, तो अगली बार संकलित करने पर वे फिर से उत्पन्न हो जाएंगे। आप अपने स्वयं के कैश स्टोर को निर्धारित करके परिभाषित कर सकते हैं:cache_storeविकल्प। यह फ़ाइल सिस्टम पर कैश फ़ाइलों को लिखेगा या रूबी प्रक्रियाओं या मशीनों को कैश फ़ाइलों को साझा करेगा। SASS Sass :: CacheStores :: बेस को स्टोर करने और कैश परिणाम प्राप्त करने के लिए उप-वर्ग के उदाहरण का उपयोग करता है ।

कस्टम आयातकों

SASS SCSS और SASS फ़ाइलों को आयात करने के लिए @import का उपयोग करता है और निर्दिष्ट केंद्रों के लिए एक उपयुक्त पथ कोड खोजने के लिए @import नियम के लिए मार्ग पास करता है। SASS आयातकों कोड लोड करने के लिए फ़ाइल सिस्टम का उपयोग करते हैं और डेटाबेस या विभिन्न फ़ाइल नामकरण योजना का उपयोग करके लोड में जोड़ा जाता है।

सिंगल इम्पोर्टर सिंगल फाइल लोडिंग ले सकता है और इसे फाइल सिस्टम के रास्तों के साथ load_paths एरे में रखा जा सकता है। @Import का उपयोग करते समय , SASS लोड किए गए रास्तों की तलाश करता है, जो आयातक के लिए पथ को आयात करते हैं। जब पथ मिल जाता है, तो आयातित फ़ाइल का उपयोग किया जाता है। उपयोगकर्ता आयातकों को इनहेरिट कर सकता हैSass::Importers::Base