Table of Contents
Why Scss
Installation
Common syntax
Variables
Nested
Comments
Inherit
Mixin
Color processing function
Introduction file
Logic compilation
sublime paging
Home Web Front-end HTML Tutorial Get started quickly with writing CSS using sass/scss_html/css_WEB-ITnose

Get started quickly with writing CSS using sass/scss_html/css_WEB-ITnose

Jun 24, 2016 am 11:46 AM


Author of the article: Songyang






Why Scss

CSS is not a programming language, It is just a configuration file and has no life. But how can I, a large program, tolerate that the things I write cannot change dynamically, cannot be encapsulated and inherited, and cannot be xxoo, so the concept of CSS preprocessing came into being. That is, writing is one thing and using it is another thing. Scss is an option for css preprocessing. It relies on Ruby and is relatively high-quality. Similar ones include Less and so on. The debate about the quality of languages ​​is of little significance. It is similar to using one of the others well.

Installation

Ruby comes with Mac, just run:

gem install sass
Copy after login

to install the corresponding module, and then you can use:

sass --watch style.scss:style.css
Copy after login

command Monitor style.scss and automatically compile it into style.css when it changes.

Friendly reminder: When I ran the gem, it didn’t move at all. I thought it was disconnected. Later I heard that it was because of my great GFW power that I could change the source to xbao’s server to solve the problem:

$ gem sources -l$ gem sources --remove https://rubygems.org/  $ gem sources -a http://ruby.taobao.org/$ gem sources -l//然后我顺手更新了一下Ruby的版本$ sudo gem update --system 
Copy after login

After the above troubles, sass was successfully installed

Common syntax

Variables

//定义$magin : 30px; //px$blue : #1875e7; //color$side : left; //str Usage: boder-#{$side}-radius
Copy after login

All numeric type variables can be calculated accordingly.

Nested

nav {    ul {...}    border : { //注意冒号 相当于树形属性 会编译成 border-color:red        color : red;    }    a {        &:hover { color :$blue;} //&表示引用上层 会编译成 a:hover{...}    }} 
Copy after login

Comments

Standard CSS comments /* comment */ will be retained in the compiled file.

Single-line comment // comment, only retained in the SASS source file, will be omitted after compilation.

Add an exclamation mark after /* to indicate that this is an "important comment". Even when compiling in compressed mode, this line of comments will be retained and can usually be used to declare copyright information.

Inherit

Use @extend to inherit the corresponding css:

.class1 {    border:1px solid #ddd;}.class2 {    @extend .class1;    border-color: green;}
Copy after login

Pay attention to the order when writing. When compiling, the css will not adjust the order. Who You have to decide which one comes first.

Mixin

This is the illegitimate child of a function and a macro. To implement like functions, use like macros. The keywords are @mixin and @include

@mixin left($color, $value:10px) {    color:$color;    margin-left:$value;}.mydiv {    @include left($blue,15px);}
Copy after login

Color processing function

lighten(#cc3, 10%) // #d6d65cdarken(#cc3, 10%) // #a3a329grayscale(#cc3) // #808080complement(#cc3) // #33c$linkColor: #08c;a {    text-decoration:none;    color:$linkColor;    &:hover{      color:darken($linkColor,10%);    }}
Copy after login

Using this method to create a link graying effect

Introduction file

@import "style2.css";

Logic compilation

If you want to really move it, you have to make judgments and loop through regular process functions.

@if can be used alone as a condition, or can be used in combination with @else for multiple conditions

$type: monster;p {  @if $type == ocean {    color: blue;  } @else if $type == matador {    color: red;  } @else if $type == monster {    color: green;  } @else {    color: black;  }}
Copy after login

The for loop has two forms, namely: @for $var from and @for $var from to . $i represents a variable, start represents the starting value, and end represents the end value. The difference between the two is that the keyword through represents the number end, while to does not include the number end.

@for $i from 1 through 3 {  .item-#{$i} { width: 2em * $i; }}
Copy after login

The syntax of each is: @each $var in . Among them, $var represents variables, while list and map represent list type data and map type data.

$animal-list: puma, sea-slug, egret, salamander;@each $animal in $animal-list {  .#{$animal}-icon {    background-image: url('/images/#{$animal}.png');  }}$headings: (h1: 2em, h2: 1.5em, h3: 1.2em);@each $header, $size in $headings {  #{$header} {    font-size: $size;  }}
Copy after login

sublime paging

Actually, this is not considered Scss knowledge, but it is just more convenient to use it. Sublime can split the screen left and right. We can put the source file in the window on the left and the compiled one on the right to facilitate our inspection. The shortcut keys on Mac are quite perverted:

cmd+option+ctrl+2 
Copy after login

Use to move left and right

cmd+shift+[ 
Copy after login

If you think this article is helpful to you, you can give it a like, not only I won’t be happy to be a father, but I can also let more people see it...

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Difficulty in updating caching of official account web pages: How to avoid the old cache affecting the user experience after version update? Difficulty in updating caching of official account web pages: How to avoid the old cache affecting the user experience after version update? Mar 04, 2025 pm 12:32 PM

The official account web page update cache, this thing is simple and simple, and it is complicated enough to drink a pot of it. You worked hard to update the official account article, but the user still opened the old version. Who can bear the taste? In this article, let’s take a look at the twists and turns behind this and how to solve this problem gracefully. After reading it, you can easily deal with various caching problems, allowing your users to always experience the freshest content. Let’s talk about the basics first. To put it bluntly, in order to improve access speed, the browser or server stores some static resources (such as pictures, CSS, JS) or page content. Next time you access it, you can directly retrieve it from the cache without having to download it again, and it is naturally fast. But this thing is also a double-edged sword. The new version is online,

How to efficiently add stroke effects to PNG images on web pages? How to efficiently add stroke effects to PNG images on web pages? Mar 04, 2025 pm 02:39 PM

This article demonstrates efficient PNG border addition to webpages using CSS. It argues that CSS offers superior performance compared to JavaScript or libraries, detailing how to adjust border width, style, and color for subtle or prominent effect

How do I use HTML5 form validation attributes to validate user input? How do I use HTML5 form validation attributes to validate user input? Mar 17, 2025 pm 12:27 PM

The article discusses using HTML5 form validation attributes like required, pattern, min, max, and length limits to validate user input directly in the browser.

What is the purpose of the <datalist> element? What is the purpose of the <datalist> element? Mar 21, 2025 pm 12:33 PM

The article discusses the HTML &lt;datalist&gt; element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

What are the best practices for cross-browser compatibility in HTML5? What are the best practices for cross-browser compatibility in HTML5? Mar 17, 2025 pm 12:20 PM

Article discusses best practices for ensuring HTML5 cross-browser compatibility, focusing on feature detection, progressive enhancement, and testing methods.

What is the purpose of the <progress> element? What is the purpose of the <progress> element? Mar 21, 2025 pm 12:34 PM

The article discusses the HTML &lt;progress&gt; element, its purpose, styling, and differences from the &lt;meter&gt; element. The main focus is on using &lt;progress&gt; for task completion and &lt;meter&gt; for stati

What is the purpose of the <meter> element? What is the purpose of the <meter> element? Mar 21, 2025 pm 12:35 PM

The article discusses the HTML &lt;meter&gt; element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates &lt;meter&gt; from &lt;progress&gt; and ex

What is the purpose of the <iframe> tag? What are the security considerations when using it? What is the purpose of the <iframe> tag? What are the security considerations when using it? Mar 20, 2025 pm 06:05 PM

The article discusses the &lt;iframe&gt; tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

See all articles