首页 > 其他 > 详细

sass个人学习笔记

时间:2015-05-11 00:00:47      阅读:337      评论:0      收藏:0      [点我收藏+]

Materliu 在慕课的视频: http://www.imooc.com/learn/364 、 http://www.imooc.com/wiki/371

sass入门:http://www.w3cplus.com/sassguide/

 

个人先看了 《Sass与Compass实战》(Materliu 是中文翻译之一)后看的视频,看书的时候不是很了解看了视频之后又看了一遍书终于少许了解sass了

下面是我个人对《Sass与Compass实战》这本书学习笔记总结,有些是个人极端自我理解少许和API解释不同

 

安装的步骤就不总结了

 

目前个人觉得也就用到这几个 当然也是书里写

compass create 项目名  创建 compass项目

compass h compass的帮助命令

compass init 为项目添加 compass

compass watch 实时编译

compass compile 生成样式表

{

gem install css_parser 安装

compass stats 查看生成的文件大小

}

 可以用图形界面的编译工具  koala 不用命令行了

 

config.rb 配置文件:

http_path = "/" 路径
css_dir = "stylesheets"  样式
sass_dir = "sass"  存放scss文件夹
images_dir = "images"  存放图片文件夹
javascripts_dir = "javascripts" 存放JS文件夹

output_style = :compact  生成CSS格式 有压缩、{}不同方式

relative_assets = false 是否是相对路径

line_comments = false  生成CSS里清楚对应scss行数

 

注释:

// 仅scss 文件内看;

/**/ 除未压缩外能看;

/*!  !*/ 都能看 压缩也能看;

注释中有会有中文编译问题 在文件第一行 @charset "utf-8";

 

@debug $style; 打印日志
@error 错误提示信息

@import "compass/reset"  引入默认样式 个人认为这个默认样式没啥用

@at-root 在嵌套里标记用的 生成出来css是独立的

@extend 是继承 不能  .a .b的继承

% 提取公共的样式,同时不编译 简称 提取公因式且不编译

$ 开头定义变量名 是个全局变量   在{ $name } 局部变量

&代表父级 a{ &:hover{} } a{} a:hover{}

.a{ .b,.c,.d{} } .a .b,.a .c,.a ,d{} 群组

.a,.b{ a{}}  .a a,.b a{}   群组

.a{ border : { style:solid;width:1px;color:#ccc } }  属性嵌套 ‘:’ 必写

_aa.scss 一般为 局部文件 其实 @import 引入的时候 _可以不写

$aa:10 !default  !default设置默认值

@mixin 混合器 @include 调用 

布尔值  and(与)\or(或)\not(非)

comparable($numver-1,$numver-2) 判断是否能相加 返回 布尔值 true/false

unit($numver) 判断 $numver 的单位

unitless($numver) 判断数值是否有单位 返回布尔值 没有单位是 true 反之 false

type-of($value) 返回类型 类似于js typeof

@function @return  必须要有返回值 

#{...} 插值

@for $i from 1 to 5 \ @for $i from 1 through 5 前者是到4不到5 后者循环到5 

@for $i from $strat through $end  开始结束如果是 strat 大就从小到大 反之亦然 

@if 判断条件{}@else{} 判断

@include a($a:10,$b:20) 可以传类似于json的值

@include link-colors(  #333,#666,#999,#f00  ); 设置 a:visited a:focus a:hover a:active 颜色

@include link-colors(#333,#00f); 设置默认没有线 hover 有线 还有文字颜色

@include ellipsis 文字超出....

@include nowrap 防止折行

@include clearfix;清浮动

 

compass css3 个人感觉就这最实用

@import “compass/css3”;

@include border-radius(5px);

 

关闭某一项浏览器的 厂商前缀

$experimental-support-for-opera:false

$experimental-support-for-microsoft:false

$experimental-support-for-khtml:false

 

图片精灵 仅支持PNG格式

@import “compass/utilities/sprites”;

@import "icons/*.png"  图片的目录名

@include all-icons-sprites;  生成所有的精灵class  ‘icons‘为目录名 生成的class名为 .目录名+图片名 .icos-ico1

<map>就是ico的目录名字

background-image:inline-image(‘../images/a.png‘); 生成base-64位的 data:images/gif;base64xxxxxxx= 

$<map>-layout:vertical(垂直)、horizontal(水平)、diagonal(对角线)、smart(智能)  

$icons-layout:smart  $icons目录名  生成的图片是四种中的哪一种 生成到原本小图标icons目录的上一级目录 命名为 小图标目录 icons-乱码.png

$<map>-spacing:0px  $icons-spacing:5px;  设置精灵图片间距  ( smart模式 不能设置图片间距 )

$<map>-<sprite>-spacing:0px;   $icons-arrow-spacing:12px; sprite其实就是你想单独间距ico的名

$<map>-sprite-width($name)、$<map>-sprite-height($name) 获取制定ico的宽高

$<map>-sprite-dimensions:true/false; 将每张ico图片设置宽高

$<map>-sprite-base-class:‘.aa‘ 更改默认文件夹icons 前缀的classname

$disable-magic-sprie-selectors:true/false; 默认开启 是通过图片名 a_hover.png 图片生成伪选择器 a{ background-position:0 0 } a:hover{background-position:10px 10px}

个人觉得有用的 图片精灵自定义:

sprite-map($glob,...) 生成图片的url复制给变量,同时可以设置一些配置参数

$icons:sprite-map("icons/*.png",$layout:vertical,$arrow-spacing:5px)  定义图片的变量名

sprite($map,$sprite,[$offset-x],[$offset-y]);   生成自定义的图片

sprite-position($map,$sprite,[$offset-x],[$offset-y]) 设置backgournd-positon:x y 位置

backgurnd:sprite-position($icons,arrow);     设置backgournd-positon:x y 位置

sprite-background-position($map,$sprite,[$offset-x],[$offset-y]); 设置backgournd-positon:x y 位置

@include sprite-background-position($icons,arrow); 返回的精灵的x y 位置

@include sprite-dimensions($icons,arrow) 返回的精灵的宽高

 例子:

$icons:sprite-map("icons/*.png"); 

.sprite-base{background:$icons no-repeat;}

.next{

  @extend .sprite-base;

  @include sprite-backgournd-position($icons,arrow);

  @include sprite-dimensions($icons,arrow);

}

 

写完发现 越来越来越像书的压缩版和 API 了还不如人家做的.....

 

做了一个小小DEMO 

上图:

技术分享

 

整个文件目录截图:

技术分享

images 截图:

技术分享

生成ico的 icons里的截图:

技术分享

sass截图

技术分享

stylesheets截图

技术分享

html部分:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>厘米IT学院    </title>
    <link rel="stylesheet" type="text/css" href="stylesheets/itlimi.css" />
</head>
<body>
    <!-- 头部 导航 start  -->
    <div class="content">
        <div class="nav-top">
            <div class="log"><a href="#"></a></div>
            <ul class="nav">
                <li><a href="#">首  页</a></li>
                <li><a href="#">培训课程</a></li>
                <li><a href="#">优秀学员</a></li>
                <li><a href="#">课程疑问</a></li>
                <li><a href="#">职业生涯</a></li>
                <li><a href="#">学员社区</a></li>
                <li><a href="#">官方博客</a></li>
                <li><a href="#">学院地址</a></li>
            </ul>
        </div>
        <!-- 头部 导航 end  -->

        <!-- 广告 start  -->
        <div class="adve">
            <img src="images/bannerImg.jpg" alt="">
        </div>
        <!-- 广告 end  -->
        
        <!-- 主体 start  -->
        <div class="box-main">
            <!-- right start  -->    
            <div class="box-right">
                <dl class="dl-list">
                    <dt>
                        职业生涯
                    </dt>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            Web前端开发工程师需要掌握哪些核心技能?
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            我是程序员,有必要进行web前端开发的学习吗?
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            我是网站美工,目前发展遇到瓶颈,该如何解决?
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            我适合从事web前端开发行业吗?
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            Web前端工程师如何给自己定位?
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            Web前端开发工程师好找工作吗?
                        </a>
                    </dd>
                </dl>
                <dl class="dl-list">
                    <dt>
                        好职推荐
                    </dt>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            盛大网络--前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            阿里巴巴--前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            金山软件--KIS-WEB前端页面工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            360京东商城 -- Web前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            阿里巴巴 - 技术部 - Web前端开发工程师(高
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            人人网 - 技术部 - 3G前端工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            人人网 - 技术部 - Web前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            搜狐 - 媒体技术产品中心 - JavaScript前端
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            新浪 - 运营部 - Web前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            新浪 - 无线部 - Web前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            新浪 - 技术部 - Web前端开发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            新浪 - 产品部 - JavaScript前端工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            百度 - Web前端研发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            百度 - 商务搜索 - Web前端研发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            百度 - 社会化网络事业部 - JavaScript前端
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            百度 - 搜索研发部 - web前端研发工程师
                        </a>
                    </dd>
                    <dd>
                        <span>
                            &nbsp;
                        </span>
                        <a href="#">
                            百度 - 系统部 - WEB前端开发工程师
                        </a>
                    </dd>
                </dl>
            </div>
               <!-- right end  -->
    
            <!-- left start  -->    
            <div class="box-left">
                <div class="min-adve">
                    <img src="images/articleBanner.jpg" alt="">
                </div>
                <h2 class="tit">Web前端开发工程师好找工作吗?</h2>
                <div class="txt-info">
                        据09年全国Web前端开发行业调查统计显示,09年大型企业对于Web前端开发人才需求紧缺。 Web前端开发目前是一种新兴职业,专业的前端开发人员绝大部分存在于大型企业中,如腾讯、百度等,换种说法就是:选择从事Web前端开发就等于你的一只脚已经迈进了腾讯、百度等高薪企业。

                        随着Web2.0的大潮席卷而来,2010年互联网发展速度空前,互联网向标准化、专业化、精细化方向发展,导致Web开发职位进一步细分,Web 前端开发工程师、Web页面重构师等这些高薪职业相继诞生。如今流行的浏览器有十几种,不同的浏览器对页面的解析不同,导致相同的页面在不同的浏览器内显示效果不同,不能兼容多种浏览器,用户体验降低,搜索引擎抓取率低,加载速度慢等影响页面整体质量的因素产生,所以对页面制作要求越来越高,致使许多公司急需提供制作标准页面服务的技术人员。

                        现在YAHOO、MSN等国际门户网站,网易、新浪等国内门户网站,和主流的Web2.0网站,均采用xHTML(DIV)+CSS的框架模式,更加印证了xHTML(DIV)+CSS是大势所趋。

                        正因为如此Web前端开发人员成为市场上紧缺的人才,同时也成为一个新兴的高薪职业。
                </div>
            </div>
               <!-- left end  -->
        
            
        </div>
        <!-- 主体 end  -->

        <!-- 尾部 start  -->
        <div class="foot">
            <p>
                <a href="#">关于W3CStudy</a>
                |
                <a href="#">广告服务</a>
                |
                <a href="#">提交问题</a>
                |
                <a href="#">联系我们</a>
                |
                <a href="#">版权声明</a>
                |
                <a href="#">关于隐私</a>
                |
                <a href="#">合作伙伴</a>
            </p>
            <p>
                京ICP备10055601号  All rights(C)2008-2010 Reserved
            </p>
        </div>
        <!-- 尾部 end  -->
    </div>
</body>
</html>

 

主要 itlimi.scss 样式

@charset "utf-8";
@import "compass/css3"; 
@import "tsass";  // 默认的样式库
@import "compass/utilities/sprites";


$icons-bgs: sprite-map("icons/*.png",$layout:vertical,$spacing:15px);//图片精灵路径 


@include treset();  // tsass.scss 重置默认样式
@include font-sizes(12,24,px); // tsass.scss 生成初始字体12-24
@include init-Style(ml,margin-left,px,5,10); // tsass.scss 生成初始margin-left左外边距 5-15

.sprite-base{
    background: $icons-bgs no-repeat;
}

//初始一些 颜色值
$gray:#393838;  
$gray2:#eaeaea;
$red:#810000;
$white:#fff;


body{ background:url(../images/bodyBg.png) no-repeat 0 0;}
.content{
    width:1000px;
    margin:0 auto;
    @include border-radius(5px);
}

/* 导航条 */
.nav-top{
    $hei:54px;

    margin :{
        top:$hei;
    };
    height:$hei;
    background-color:$gray;
    
    %top-public{
        float:left;
        height:$hei;
     }

    .log{
        width:220px;
        @extend %top-public;
        a{
            display:block;
            @extend .sprite-base;
            background-position:sprite-position($icons-bgs,logo);
            @include sprite-dimensions($icons-bgs,logo);
        }
    }
    @at-root .nav{
        li{
            @extend %top-public;
            width:86px;
            line-height: $hei;
            text-align: center;

        }
        a{
            display:block;
            font-size: 12px;
            color: #ccc;
        }
        a:hover{
            color:$white;
            background: $icons-bgs no-repeat;
            background-position:sprite-position($icons-bgs,navActive);
        }


    }

    & a{
        
        text-decoration: none;
    }
}

/* 广告 */
.adve{
    height:292px;
    overflow:hidden;
    margin:10px 0;
}


.box-main{
    background:$gray2;
    padding:10px;
    overflow:hidden;
}

.box-left{
    width:660px;
}

.tit{
    font-size: 22px;
    font-weight: bold;
    line-height: 66px;
    color:$red;
}
.txt-info{ 
    text-indent:2em;
    font-size:14px;
    line-height: 24px;
}

.box-right{
    float:right;
    width:300px;
}

.dl-list{
    padding-bottom:10px;
    dt{
        height:32px;
        line-height: 32px;
        padding-left:20px;
        color:$white;
        font-size: 14px;
        @extend .sprite-base;
        background-color:$red;
        background-position:sprite-position($icons-bgs,fries,7,6);
        margin-bottom:4px;
    }
    dd{
        position:relative;
        line-height: 24px;
        font-size: 12px;
        padding-left:17px;
        span{
            position:absolute;
            left:8px;
            top:12px;
            width:3px;
            height:3px;
            background-image:inline-image(‘../images/dot.png‘);
        }
        a{
            text-decoration: none;
            color:#000;
        }
    }
}

/* 尾部 */
.foot{
    background-color:$gray;
    margin-top:10px;
    padding:15px 0;
    font-size: 12px;
    color:$white;
    p{
        text-align: center;
        line-height: 20px;
        a{
            text-decoration: none;
            color:$white;
        }
    }

}

应用 tsass.scss 

@charset "utf-8";
@mixin treset(){
    html {margin: 0; padding: 0; border: 0;}
    body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, code, del, dfn, em, img, q, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, caption, tbody, tfoot, thead, article, aside, dialog, figure, footer, header, hgroup, nav, section { margin: 0; padding: 0; border: 0; font-size: 100%; vertical-align: baseline; }
    ol, ul, li { list-style: none; }
    table,tr, th, td { border-collapse: collapse; margin: 0; padding: 0;  font-size: 100%; vertical-align: baseline;}
    caption, th, td { text-align: left; font-weight: normal; }
    input,select{margin:0;padding:0}
    a:hover { text-decoration: underline; }
    img { border: none; }
    textarea{ resize:none;border:1px solid #ccc;}
}

//浮动
@mixin float($dir:left){
    float:$dir;
}


//设置默认字体class
@mixin font-sizes( $strat:0 , $end:100 ,$oUnit:px ){

    @if( TestNum( $strat,$end ) ){
        @for $i from $strat through $end {
            @if( $i%2 == 0 ){
                .f-#{$i}{ font-size:$i+$oUnit; }
            }
        }
    }
}


//判断是否为数字
@function TestNum( $num1,$num2 ){
    
    @if ( not unitless($num1) or not unitless($num2) ){
        @debug "其中数值有单位";
        @return false;
    }
    @if ( type-of($num1) == number and type-of($num1) == number ) {
        @return true;
    }@else{
        @debug "其中有值不数字";
        @return false;
    }
}

//初始class
@mixin init-Style( $class,$styles,$oUnit:px, $strat:0 , $end:100 ){

    @if( TestNum( $strat,$end ) ){
        @for $i from $strat through $end {
            .#{$class}-#{$i}{ #{$styles}:$i+$oUnit; }
        }
    }

}

config.rb配置文件:

require ‘compass/import-once/activate‘
# Require any additional compass plugins here.

# Set this to the root of your project when deployed:
http_path = "../"
css_dir = "stylesheets"
sass_dir = "sass"
images_dir = "images"
javascripts_dir = "javascripts"

# You can select your preferred output style here (can be overridden via the command line):
output_style = :compact

# To enable relative paths to assets via compass helper functions. Uncomment:
relative_assets = false

# To disable debugging comments that display the original location of your selectors. Uncomment:
line_comments = false

# If you prefer the indented syntax, you might want to regenerate this
# project again passing --syntax sass, or you can uncomment this:
# preferred_syntax = :sass
# and then run:
# sass-convert -R --from scss --to sass sass scss && rm -rf sass && mv scss sass

 

最终生成 itlimi.css

@charset "UTF-8";
html { margin: 0; padding: 0; border: 0; }

body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, code, del, dfn, em, img, q, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, caption, tbody, tfoot, thead, article, aside, dialog, figure, footer, header, hgroup, nav, section { margin: 0; padding: 0; border: 0; font-size: 100%; vertical-align: baseline; }

ol, ul, li { list-style: none; }

table, tr, th, td { border-collapse: collapse; margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; }

caption, th, td { text-align: left; font-weight: normal; }

input, select { margin: 0; padding: 0; }

a:hover { text-decoration: underline; }

img { border: none; }

textarea { resize: none; border: 1px solid #ccc; }

.f-12 { font-size: 12px; }

.f-14 { font-size: 14px; }

.f-16 { font-size: 16px; }

.f-18 { font-size: 18px; }

.f-20 { font-size: 20px; }

.f-22 { font-size: 22px; }

.f-24 { font-size: 24px; }

.ml-5 { margin-left: 5px; }

.ml-6 { margin-left: 6px; }

.ml-7 { margin-left: 7px; }

.ml-8 { margin-left: 8px; }

.ml-9 { margin-left: 9px; }

.ml-10 { margin-left: 10px; }

.sprite-base, .nav-top .log a, .dl-list dt { background: url(‘../images/icons-s46c7590030.png‘) no-repeat; }

body { background: url(../images/bodyBg.png) no-repeat 0 0; }

.content { width: 1000px; margin: 0 auto; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; }

/* 导航条 */
.nav-top { margin-top: 54px; height: 54px; background-color: #393838; }
.nav-top .log, .nav-top .nav li, .nav .nav-top li { float: left; height: 54px; }
.nav-top .log { width: 220px; }
.nav-top .log a { display: block; background-position: 0 -37px; height: 54px; width: 220px; }
.nav li { width: 86px; line-height: 54px; text-align: center; }
.nav a { display: block; font-size: 12px; color: #ccc; }
.nav a:hover { color: white; background: url(‘../images/icons-s46c7590030.png‘) no-repeat; background-position: 0 -106px; }
.nav-top a { text-decoration: none; }

/* 广告 */
.adve { height: 292px; overflow: hidden; margin: 10px 0; }

.box-main { background: #eaeaea; padding: 10px; overflow: hidden; }

.box-left { width: 660px; }

.tit { font-size: 22px; font-weight: bold; line-height: 66px; color: #810000; }

.txt-info { text-indent: 2em; font-size: 14px; line-height: 24px; }

.box-right { float: right; width: 300px; }

.dl-list { padding-bottom: 10px; }
.dl-list dt { height: 32px; line-height: 32px; padding-left: 20px; color: white; font-size: 14px; background-color: #810000; background-position: 7px 6px; margin-bottom: 4px; }
.dl-list dd { position: relative; line-height: 24px; font-size: 12px; padding-left: 17px; }
.dl-list dd span { position: absolute; left: 8px; top: 12px; width: 3px; height: 3px; background-image: url(‘‘); }
.dl-list dd a { text-decoration: none; color: #000; }

/* 尾部 */
.foot { background-color: #393838; margin-top: 10px; padding: 15px 0; font-size: 12px; color: white; }
.foot p { text-align: center; line-height: 20px; }
.foot p a { text-decoration: none; color: white; }

 

心得

刚开始写的时候有点不太习惯,之后我就把sass当成JS封方法的感觉在写就好多了 没个css模块就是一个 大的function 里面可能有几个子的方法的概念,

在写 @function 、@if 老感觉在写JS常常忘记@ 然后就编译老报错看代码还觉得没错啊,原来忘了写@

 

sass个人学习笔记

原文:http://www.cnblogs.com/auok/p/4469263.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!