സാസ് (സ്റ്റൈൽ‌ഷീറ്റ് ഭാഷ)

വിക്കിപീഡിയ, ഒരു സ്വതന്ത്ര വിജ്ഞാനകോശം.
Sass
രൂപകൽപ്പന ചെയ്തത്:Hampton Catlin
വികസിപ്പിച്ചത്:Natalie Weizenbaum, Chris Eppstein
ഏറ്റവും പുതിയ പതിപ്പ്:3.5.6/ മാർച്ച് 23, 2018; 5 വർഷങ്ങൾക്ക് മുമ്പ് (2018-03-23)[1]
ഡാറ്റാടൈപ്പ് ചിട്ട:Dynamic
പ്രധാന രൂപങ്ങൾ:Dart, Ruby
സ്വാധീനിക്കപ്പെട്ടത്:CSS (both "indented" and SCSS)

YAML and Haml (indented syntax)

Less (SCSS)
സ്വാധീനിച്ചത്:Less, Stylus, Tritium, Bootstrap (v4+)
ഓപറേറ്റിങ്ങ് സിസ്റ്റം:Cross-platform
അനുവാദപത്രം:MIT License
വെബ് വിലാസം:sass-lang.com

തുടക്കത്തിൽ ഹാംപ്ടൺ കാറ്റ്‌ലിൻ രൂപകൽപ്പന ചെയ്തതും നതാലി വീസെൻ‌ബോം വികസിപ്പിച്ചെടുത്തതുമായ ഒരു സ്റ്റൈൽ ഷീറ്റ് ഭാഷയാണ് സാസ് (Sass-short for syntactically awesome style sheets).[2][3]പ്രാരംഭ പതിപ്പുകൾക്ക് ശേഷം, വീസെൻ‌ബോമും ക്രിസ് എപ്‌സ്റ്റൈനും സാസ് ഫയലുകളിൽ ഉപയോഗിക്കുന്ന ലളിതമായ സ്ക്രിപ്റ്റിംഗ് ഭാഷയായ സാസ്‌ക്രിപ്റ്റിനൊപ്പം സാസ് വിപുലീകരിക്കുന്നത് തുടരുകയാണ്.

കാസ്കേഡിംഗ് സ്റ്റൈൽ ഷീറ്റുകളിലേക്ക് (സി‌എസ്‌എസ്) വ്യാഖ്യാനിക്കുകയോ സമാഹരിക്കുകയോ ചെയ്യുന്ന ഒരു പ്രീപ്രൊസസ്സർ‌ സ്ക്രിപ്റ്റിംഗ് ഭാഷയാണ് സാസ്. സാസിൽ രണ്ട് വാക്യഘടനകളുണ്ട്. ഒറിജിനൽ സിന്റാക്സ്, "ഇൻഡന്റ് ചെയ്ത വാക്യഘടന", ഹാമലിന് സമാനമായ ഒരു വാക്യഘടന ഉപയോഗിക്കുന്നു.[4]കോഡ് ബ്ലോക്കുകൾ വേർതിരിക്കുന്നതിന് ഇത് ഇൻഡന്റേഷനും നിയമങ്ങൾ വേർതിരിക്കുന്നതിന് ന്യൂലൈൻ പ്രതീകങ്ങളും ഉപയോഗിക്കുന്നു.

ഏറ്റവും പുതിയ വാക്യഘടന, "എസ്‌സി‌എസ്എസ്" (സാസി സി‌എസ്‌എസ്), സി‌എസ്‌എസിനെപ്പോലെ ബ്ലോക്ക് ഫോർ‌മാറ്റിംഗ് ഉപയോഗിക്കുന്നു. ഒരു ബ്ലോക്കിനുള്ളിലെ വരികൾ വേർതിരിക്കുന്നതിന് കോഡ് ബ്ലോക്കുകളെയും അർദ്ധവിരാമങ്ങളെയും സൂചിപ്പിക്കാൻ ഇത് ബ്രേസുകൾ ഉപയോഗിക്കുന്നു. ഇൻഡന്റ് ചെയ്ത വാക്യഘടന, എസ്‌സി‌എസ്എസ് ഫയലുകൾക്ക് പരമ്പരാഗതമായി യഥാക്രമം .sass, .scss എന്നീ എക്സ്റ്റൻഷനുകൾ നൽകുന്നു.

സിഎസ്എസ്3(CSS3)[5] സെലക്ടർമാരുടെയും സ്യൂഡോ-സെലക്ടർമാരുടെയും ഒരു ശ്രേണി ഉൾക്കൊള്ളുന്നു, അവയ്ക്ക് ബാധകമായ ഗ്രൂപ്പ് നിയമങ്ങളുമുണ്ട്. കൂടുതൽ പരമ്പരാഗത പ്രോഗ്രാമിംഗ് ഭാഷകളിൽ, പ്രത്യേകിച്ചും ഒബ്ജക്റ്റ്-ഓറിയെന്റഡ് ഭാഷകളിൽ ലഭ്യമായ നിരവധി സംവിധാനങ്ങൾ നൽകിക്കൊണ്ട് സാസ് (രണ്ട് സിന്റാക്സുകളുടെയും വലിയ പശ്ചാത്തലത്തിൽ) സി‌എസ്‌എസ് വിപുലീകരിക്കുന്നു, പക്ഷേ അവ സി‌എസ്‌എസ് 3 ന് തന്നെ ലഭ്യമല്ല. സാസ്ക്രിപ്റ്റ് വ്യാഖ്യാനിക്കുമ്പോൾ, സാസ് ഫയൽ നിർവചിച്ചിരിക്കുന്ന പ്രകാരം വിവിധ സെലക്ടർമാർക്ക് ഇത് സി‌എസ്‌എസ് നിയമങ്ങളുടെ ബ്ലോക്കുകൾ സൃഷ്ടിക്കുന്നു. സാസ് ഇന്റപ്രെറ്റർ സി‌എസ്‌എസിലേക്ക് സാസ്‌ക്രിപ്റ്റിനെ വിവർത്തനം ചെയ്യുന്നു. മറ്റൊരു തരത്തിൽ, .sass അല്ലെങ്കിൽ .scss ഫയൽ നിരീക്ഷിക്കാനും .sass അല്ലെങ്കിൽ .scss ഫയൽ സംരക്ഷിക്കുമ്പോഴെല്ലാം ഔട്ട്‌പുട്ട് .css ഫയലിലേക്ക് വിവർത്തനം ചെയ്യാനും സാസിന് കഴിയും.[6]

ഇൻഡന്റ് ചെയ്ത വാക്യഘടന ഒരു മെറ്റലാങ്വേജ് ആണ്. എസ്‌സി‌എസ്എസ് ഒരു നെസ്റ്റഡ് മെറ്റലാംഗ്വേജാണ്, കാരണം സാധുവായ സി‌എസ്‌എസ് ഒരേ സെമാന്റിക്‌സിനൊപ്പം സാധുവായ എസ്‌സി‌എസ്എസ് ആണ്.

സാസ്ക്രിപ്റ്റ് ഇനിപ്പറയുന്ന സംവിധാനങ്ങൾ നൽകുന്നു: വേരിയബിളുകൾ, നെസ്റ്റിംഗ്, മിക്സിനുകൾ, സെലക്ടർ ഇൻഹെറിറ്റൻസ്.

ചരിത്രം[തിരുത്തുക]

സാസ് തുടക്കത്തിൽ രൂപകൽപ്പന ചെയ്തത് ഹാംപ്ടൺ കാറ്റ്‌ലിൻ ആണ്, ഇത് വികസിപ്പിച്ചെടുത്തത് നതാലി വീസെൻ‌ബോം ആണ്.<[7]പ്രാരംഭ പതിപ്പുകൾക്ക് ശേഷം, വീസെൻ‌ബോമും ക്രിസ് എപ്‌സ്റ്റൈനും സാസ് ഫയലുകളിൽ ഉപയോഗിക്കുന്ന സ്ക്രിപ്റ്റിംഗ് ഭാഷയായ സാസ്‌ക്രിപ്റ്റിനൊപ്പം സാസ് വിപുലീകരിക്കുന്നത് തുടരുന്നുകൊണ്ടിരിക്കുന്നു.

പ്രധാന നടപ്പാക്കലുകൾ[തിരുത്തുക]

ഒന്നിലധികം ഭാഷകളിൽ സാസ്‌ക്രിപ്റ്റ് നടപ്പിലാക്കി, ശ്രദ്ധേയമായ നടപ്പാക്കലുകൾ ഇവയാണ്:

  • 2006[8] ൽ സൃഷ്ടിച്ച യഥാർത്ഥ ഓപ്പൺ സോഴ്‌സ് റൂബി നടപ്പാക്കൽ,പരിപാലകരുടെ അഭാവം മൂലം ഒഴിവാക്കി 2019 മാർച്ചിൽ അതിന്റെ പ്രവർത്തനം അവസാനിപ്പിച്ചു.[9][10]
  • ഔദ്യോഗിക ഓപ്പൺ സോഴ്‌സ് ഡാർട്ട് നടപ്പാക്കൽ.
  • ലിബ്സാസ്(libSass), ഔദ്യോഗിക ഓപ്പൺ സോഴ്‌സ് സി++ നടപ്പിലാക്കൽ.
  • ഔദ്യോഗിക ജാവാസ്ക്രിപ്റ്റ് നടപ്പിലാക്കൽ, എൻപിഎം(npm)ന് "സാസ്" മൊഡ്യൂളായി പ്രസിദ്ധീകരിച്ചു.
  • ജെസാസ്(JSass), അനഔദ്യോഗിക ജാവ നടപ്പാക്കൽ.
  • പാംഎൽപി(phamlp), പി‌എച്ച്പിയിലെ അനഔദ്യോഗിക SASS / SCSS നടപ്പാക്കൽ.
  • വാഡിന്(Vaadin) സാസിന്റെ ജാവ നടപ്പാക്കാനുണ്ട്(implementation).
  • ഫയർ‌ബഗ്, വെബ് വികസനത്തിനായുള്ള ഒരു ഫയർ‌ഫോക്സ് എക്സ്യുഎൽ(XUL) ("ലെഗസി") വിപുലീകരണം. ഫയർഫോക്സിൽ തന്നെ സംയോജിപ്പിച്ച ഡവലപ്പർ ഉപകരണങ്ങൾക്ക് ഉണ്ടായിരുന്നത് പിന്നീട് ഒഴിവാക്കി. ഫയർഫോക്സ് 57ൽ എക്സ്യുഎൽ എക്സ്റ്റെൻഷനുകൾക്കുള്ള പിന്തുണ ഉപേക്ഷിച്ചതിനാൽ ഇത് പ്രവർത്തിക്കുന്നത് നിർത്തി.

സവിശേഷതകൾ[തിരുത്തുക]

വേരിയബിളുകൾ[തിരുത്തുക]

വേരിയബിളുകൾ നിർവചിക്കാൻ സാസ് അനുവദിക്കുന്നു. ഒരു ഡോളർ ചിഹ്നത്തിൽ ($) വേരിയബിളുകൾ ആരംഭിക്കുന്നു. വേരിയബിൾ അസൈൻ‌മെന്റ് ഒരു കോളൻ (:) ഉപയോഗിച്ചാണ് ചെയ്യുന്നത്.[11]

സാസ്ക്രിപ്റ്റ് നാല് ഡാറ്റ ടൈപ്പുകളെ പിന്തുണയ്ക്കുന്നു:[11]

  • നമ്പറുകൾ (യൂണിറ്റുകൾ ഉൾപ്പെടെ)
  • സ്ട്രിംഗുകൾ (ഉദ്ധരണികളോടുകൂടിയോ അല്ലാതെയോ)
  • നിറങ്ങൾ (പേര് അല്ലെങ്കിൽ പേരുകൾ)
  • ബൂലിയൻസ്(Booleans)

ലഭ്യമായ നിരവധി ഫംഗ്ഷനുകളിലൊന്നിൽ നിന്നുള്ള വേരിയബിളുകളോ റിസൾട്ടുകളോ ആകാം.[12]വിവർത്തന സമയത്ത്, വേരിയബിളുകളുടെ മൂല്യങ്ങൾ ഔട്ട്‌പുട്ട് സിഎസ്എസ്(CSS)ഡോക്യുമെന്റിലേക്ക് തിരുകികയറ്റുന്നു.[4]

എസ്‌സി‌എസ്‌എസ് സാസ് കംപൈൽഡ് സിഎസ്എസ്
$primary-color: #3bbfce;
$margin: 16px;

.content-navigation {
  border-color: $primary-color;
  color: darken($primary-color, 10%);
}

.border {
  padding: $margin / 2;
  margin: $margin / 2;
  border-color: $primary-color;
}
$primary-color: #3bbfce
$margin: 16px

.content-navigation
  border-color: $primary-color
  color: darken($primary-color, 10%)

.border
  padding: $margin/2
  margin:  $margin/2
  border-color: $primary-color
.content-navigation {
  border-color: #3bbfce;
  color: #2b9eab;
}

.border {
  padding: 8px;
  margin: 8px;
  border-color: #3bbfce;
}

അവലംബം[തിരുത്തുക]

  1. Latest releases
  2. "Sass: Syntactically Awesome Style Sheets". sass-lang.com. മൂലതാളിൽ നിന്നും 2013-09-01-ന് ആർക്കൈവ് ചെയ്തത്.
  3. "Natalie Weizenbaum's blog". മൂലതാളിൽ നിന്നും 2007-10-11-ന് ആർക്കൈവ് ചെയ്തത്.
  4. 4.0 4.1 Media Mark (3.2.12). "Sass - Syntactically Awesome Stylesheets". Sass-lang.com. ശേഖരിച്ചത് 2014-02-23.
  5. Kataria, Saransh (2015-09-02). "Getting started with sass development". wisdomgeek. saranshkataria.
  6. Sass - Syntactically Awesome Stylesheets Tutorial
  7. "Natalie Weizenbaum's blog". മൂലതാളിൽ നിന്നും 2007-10-11-ന് ആർക്കൈവ് ചെയ്തത്.
  8. "Sass / Scss". Drupal.org. 2009-10-21. ശേഖരിച്ചത് 2014-02-23.
  9. Weizenbaum, Natalie. "Ruby Sass Has Reached End-Of-Life « Sass Blog". sass.logdown.com. ശേഖരിച്ചത് 2019-04-21.
  10. "Sass: Ruby Sass". sass-lang.com. ശേഖരിച്ചത് 2019-04-21.
  11. 11.0 11.1 Sass (Syntactically Awesome StyleSheets) SASS_REFERENCE
  12. Module: Sass::Script::Functions Sass Functions