لس (زبان برنامه‌نویسی)

Less (گاهی اوقات به صورت LESS) یک زبان پویای style sheet است که می‌تواند به صورت شیوه نامه‌های آبشاری (CSS) کامپایل شود در سمت کلاینت یا سرور اجرا شود.[1] Less توسط الکسیس سلیر طراحی شده‌است. Less از Sass تأثیر گرفته‌است و بر سینتکس جدیدتر "SCSS" از Sass تأثیر گذاشته‌است، که سازگار با سینتکس قالب‌بندی بلاک CSS-like است.[2] Less متن‌باز است. اولین نسخهٔ آن با زبان روبی نوشته شده‌است؛ اما در نسخه‌های بعدی استفاده از روبی پایان یافت و با جاوا اسکریپت جایگزین شد. سینتکس فاصله‌گذاری Less به صورت یک فرازبان تو در تو است به صورتی که CSS معتبر یک کد معتبر Less با معانی مشابه است. Less این مکانیزم‌ها را فراهم می‌کند: متغیر، nesting, mixins, operators و توابع؛ تفاوت اصلی بین Less و سایر زبان‌های CSS پیش‌کامپایل این است که Less اجازه می‌دهد که کامپایل به صورت real-time از طریق less.js توسط مرورگر انجام شود.[3]

Less
طراحی شده توسطالکسیس سلیر
توسعه‌دهندهالکسیس سلیر، دیمیتری فادایف
ظهوریافته در2009
انتشار پایدار
۲٫۷٫۲
۴ ژانویهٔ ۲۰۱۷، ۶ ماه پیش
dynamic
زبان پیاده‌سازی
[[جاوااسکریپت]]
سیستم‌عامل[[چندسکویی]]
پروانه[[مجوز آپاچی]] ۲
.less
وبگاه
متأثر از
[[شیوه‌نامه آبشاری]]، Sass
تأثیر گذاشته بر
Sass, Less Framework, [بوتسترپ|بوت‌استرپ (چارچوب انتهایی)]

متغیرها

Less اجازه می‌دهد که متغیر تعریف شود. متغیرها در Less با یک علامت (@) تعریف می‌شوند. متغیر با یک علامت دونقطه (:) مقداردهی می‌شود.

در حین ترجمه، مقادیر متغیرها به فایل خروجی CSS وارد می‌شوند.

@pale-green-color: #4D926F;
#header {
  color: @pale-green-color;
}
h2 {
  color: @pale-green-color;
}

کد بالا در Less که به کد زیر در CSS کامپایل می‌شود.

#header {
  color: #4D926F;
}
h2 {
  color: #4D926F;
}

مکسین‌ها

مکسین‌ها اجازه می‌دهند که همهٔ خصوصیات یک کلاس از طریق وارد کردن نام کلاس به عنوان یکی از خصوصیاتش وارد کلاس دیگر شود، بنابراین به عنوان یک نوع ثابت یا متغیر رفتار می‌کند. همچنین می‌توانند مانند توابع رفتار کنند و آرگومان بگیرند. CSS از مکسین‌ها پشتیبانی نمی‌کند. هر کد تکرارشونده‌ای باید در جای خود تکرار شود. مکسین‌ها اجازه می‌دهند که کد کارآمدتر و تکرار در کد تمیز باشد، و همچنین تغییر کد راحت‌تر باشد.

.rounded-corners (@radius: 5px 10px 8px 2px) {
  -webkit-border-radius: @radius;
  -moz-border-radius: @radius;
  border-radius: @radius;
}
#header {
  .rounded-corners;
}
#footer {
  .rounded-corners(10px 25px 35px 0px);
}

کد بالا در Less که به کد زیر در CSS کامپایل می‌شود.

#header {
  -webkit-border-radius: 5px 10px 8px 2px;
  -moz-border-radius: 5px 10px 8px 2px;
  border-radius: 5px 10px 8px 2px;
}
#footer {
  -webkit-border-radius: 10px 25px 35px 0px;
  -moz-border-radius: 10px 25px 35px 0px;
  border-radius: 10px 25px 35px 0px;
}

Less یک نوع خاص از مجموعه قوانین به نام مکسین‌های پارامتری دارد که می‌تواند مانند کلاس‌ها میکس شود، اما پارامتر قبول کند.

#header {
  h1 {
    font-size: 26px;
    font-weight: bold;
  }
  p {
    font-size: 16px;
    a {
      text-decoration: none;
      color: red;
      &:hover {
        border-width: 1px;
        color: #fff;
      }
    }
  }
}

کد بالا در Less که به کد زیر در CSS کامپایل می‌شود.

#header h1 {
  font-size: 26px;
  font-weight: bold;
}
#header p {
  font-size: 16px;
}
#header p a {
  text-decoration: none;
  color: red;
}
#header p a:hover {
  border-width: 1px;
  color: #fff;
}

توابع و عملیات‌ها

Less اجازهٔ تعریف عملیات‌ها و توابع را می‌دهد. عملیات‌ها اجازهٔ جمع، تفریق، تقسیم و ضرب مقادیر خصوصیت‌ها و رنگ‌ها را می‌دهد که می‌توانند برای ایجاد روابط پیچیده بین خصوصیت‌ها استفاده شوند. توابع، به صورت یک-به-یک با کد جاوااسکریپت نگاشت می‌شوند که اجازهٔ دستکاری متغیرها را می‌دهد.

@the-border: 1px;
@base-color: #111;
@red:        #842210;
#header {
  color: @base-color * 3;
  border-left: @the-border;
  border-right: @the-border * 3;
}
#footer {
  color: @base-color + #003300;
  border-color: desaturate(@red, 10%);
}

کد بالا در Less که به کد زیر در CSS کامپایل می‌شود.

#header {
  color: #222;
  border-left: 1px;
  border-right: 3px;
}
#footer {
  color: #114411;
  border-color: #7d2717;
}

مقایسه

Sass

هم Sass و هم Less هر دو پیش‌پردازندهٔ CSS هستند که اجازه می‌دهند کد CSS به جای قواعد استاتیک در یک ساختار برنامه‌نویسی نوشته شود.[4]

Less الهام‌گرفته از Sass است.[5] Sass به منظور ساده‌سازی و توسعه دادن CSS طراحی شده‌است، به طوری که چیزهایی ماند آکولاد از سینتکس حذف شده‌است. Less طراحی شده‌است تا نزدیکی به CSS ممکن باشد، و یک نتیجهٔ موجود CSS به صورت یک کد Less معتبر باشد.

نسخهٔ جدیدتر Sass نیز با سینتکس CSS-like به نام SCSS (Sassy CSS) معرفی شده‌است.

برای مقایسهٔ بیشتر سینتکس‌ها لینک زیر را ببینید: https://gist.github.com/674726.

استفاده در سایت‌ها

Less می‌تواند به چند روش در سایت‌ها به کار برده شود. یک روش این است که یک فایل less.js وارد کد سایت شود تا در لحظه کد Less به CSS تبدیل شود. مرورگرها خروجی CSS را رندر می‌کنند. یکی دیگر از روش‌ها این است که کد Less به صورت CSS خالص رندر شود و در CSS سایت قرار بگیرد. در این روش فایل‌های .less آپلود نمی‌شوند و سایت نیازی به مبدل جاوااسکریپتی less.js ندارد

نرم‌افزارLess

نامتوضیحاتمجوز نرم‌افزاریسکوکارکرد
WinLessکامپایلر گرافیکی Lessمجوز آپاچی ۲٫۰[6]ویندوزکامپایلر
Crunchویرایشگر و کامپایلر Less (به Adobe AIR نیاز دارد)پروانه عمومی همگانی گنو[7]ویندوز، مکویرایشگر
کامپایلر
less.js-windowsابزار کامندلاین ساده برای ویندوز که فایل‌های .less را به وسیلهٔ less.js به CSS کامپایل می‌کند.پروانه ام‌آی‌تی[8]ویندوزکامپایلر
less.appکامپایلر Lessنرم‌افزار انحصاریمککامپایلر
CodeKitکامپایلر Lessنرم‌افزار انحصاریمککامپایلر
LessEngineکامپایلر LessآزادOpenCart Pluginکامپایلر
SimpLESSکامپایلر Lessfree but no explicit license[9]ویندوز
مک
گنو/لینوکس
کامپایلر
ChirpyکامپایلرMs-PL[10]افزونهٔ Less برای ویژوال استودیوکامپایلر
Mindscape Web WorkbenchSyntax highlighting and IntelliSense for Less and Sassنرم‌افزار انحصاریافزونهٔ ویژوال استودیوکامپایلر
Syntax Highlighting
Eclipse Plugin for Lessافزونهٔ اکلیپسEPL 1.0[11]افزونهٔ اکلیپسSyntax highlighting
Content assist
کامپایلر
mod_lessApache2 module to compile Less on the flyمتن‌بازگنو/لینوکسکامپایلر
grunt-contrib-lessNode.js Grunt task to convert Less to CSSمتن‌بازNode.jsکامپایلر
Web Essentialsافزونهٔ ویژوال استودیو که Less و Sass را پشتیبانی می‌کندمجوز آپاچی ۲٫۰ویندوزSyntax highlighting
Content assist
کامپایلر
clesscPure C++ compilerپروانه عمومی همگانی گنوآخرین نسخهٔ ویندوز
مک
گنو/لینوکس
کامپایلر

جستارهای وابسته

  • Sass (stylesheet language)
  • Stylus (stylesheet language)

منابع

  1. Official Less website Official Less website
  2. Sass and Less بایگانی‌شده در ۲۱ ژوئن ۲۰۰۹ توسط Wayback Machine Sass and Less
  3. "css - Is there a SASS.js? Something like LESS.js?". Stack Overflow.
  4. What's Wrong With CSS What's Wrong With CSS
  5. About Less About
  6. WinLess github Issue "License Information"
  7. Crunch's LICENSE.txt at github Crunch's LICENSE.txt at github
  8. github license
  9. license file at github (placeholder)
  10. Chirpy License Information at CodePlex
  11. Eclipse Plugin for Less homepage Eclipse Plugin for Less homepage

پیوند به بیرون

}

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.