做为函数混合

混合中定义的变量和混合是可见的,能够在调用者的做用域中使用,只有一个例外,那就是若是调用方包含一个具备相同名称的变量(其中包括由另外一个mixin调用定义的变量),则不会复制变量,仅存在于调用者本地范围内的变量受到保护,而从父范围继承的变量将会被覆盖。函数

  • Mixin范围spa

    由变量和混合组成的混合能够在调用者的做用域中使用,而且是可见的。code

  • Mixin和返回值继承

    mixin相似于函数,在mixin中定义的变量将做为它的返回值。作用域

  • Mixin定义另外一个mixinio

    每当一个mixin定义在另外一个mixin中时,它能够用做返回值。变量

示例:margin

// 1:正常使用
    .mixin(){
        @color: green;
        @border: 1px solid red;
        @font-size: 24px;
        @width: 100px;
        @height: 200px;
    }
    .allVar_mixin{
        .mixin();
        color: @color;
        border: @border;
        font-size: @font-size;
        width: @width;
        height: @height;
    }
    // 输出结果
    .allVar_mixin{
        color: green;
        border: 1px solid red;
        font-size: 24px;
        width: 100px;
        height: 200px;
    }
    
    
    // 2:mixin中定义的变量用做返回值
    .var_reval(@a, @b) {
      @var_reVal: ((@a + @b) / 3);
    }
    div {
      .var_reVal(15px, 30px); 
      // 使用其返回值
      margin: @var_reVal;
    }
    // 输出结果
    div {
      margin: 15px;
    }
    
    
    // 3:在调用者做用域中直接定义的变量不能被覆盖,但在调用者父做用域中定义的变量不受保护会被覆盖
    .mixin() {
      @cover: action_scope;
      @notcover: action_scope;
    }
    .xkd {
      padding: @cover @notcover;
      .mixin();
    }
    // 调用方父做用域没有保护
    @cover: parent_scope; 
    // 输出结果
    .xkd {
      padding: action_scope action_scope;
    }
    
    
    // 4:定义的mixin充当返回值
    // 外混合
    .unlock(@value) { 
    // 嵌套混合
      .mix_reval() { 
        declaration: @value;
      }
    }
    #namespace {
      // 解锁一些混合
      .unlock(8); 
      // 嵌套的mixin被复制到这里并可用
      .mix_reval(); 
    }
    // 输出结果
    #namespace {
      declaration: 8;
    }
相关文章
相关标签/搜索