组件库的封装之旅(入门scss)

简介: 这几天在封装组件库,今天和大家一起使用scss,学习一些scss的基础语法。先来看一下scss的优势SCSS (Sass) 有以下几个主要优势:- 可维护性:SCSS 允许使用变量、嵌套、混合、继承等特性,从而使样式表变得更加清晰、可读性增强。- 更高效:SCSS 允许使用函数、循环等高级特性,使得样式定义更加高效。- 更易扩展:SCSS 提供了组件化和模块化的技巧,可以更方便地扩展和维护代码。- 更简单:SCSS 的语法比 CSS 更简洁易懂,允许编写更加简洁的样式表。- 兼容性:SCSS 可以完全兼容 CSS,可以无缝地使用再来看一下scss和其他对比| | S

这几天在封装组件库,今天和大家一起使用scss,学习一些scss的基础语法。

先来看一下scss的优势

SCSS (Sass) 有以下几个主要优势:

  • 可维护性:SCSS 允许使用变量、嵌套、混合、继承等特性,从而使样式表变得更加清晰、可读性增强。
  • 更高效:SCSS 允许使用函数、循环等高级特性,使得样式定义更加高效。
  • 更易扩展:SCSS 提供了组件化和模块化的技巧,可以更方便地扩展和维护代码。
  • 更简单:SCSS 的语法比 CSS 更简洁易懂,允许编写更加简洁的样式表。
  • 兼容性:SCSS 可以完全兼容 CSS,可以无缝地使用

再来看一下scss和其他对比

Scss/Less Atomic CSS css-in-js
完全支持样式覆盖 需要使用className支持
支持rem布局 大部分库支持
可读性 稍弱
上手成本 较低
是否支持SSR 天然支持 天然支持 需要额外支持
是否支持流式渲染 天然支持 天然支持 需要额外支持
支持postcss 有自己的插件生态

看到scss这么多优势,接下来就让我们开启一段scss学习之旅吧!!!!

对原生css的支持

首先scss完全兼容css,可以使用css3在内的所有css语法进行书写

变量

scss中可以定义变量。常使用 $变量名:值 的形式来定义变量。并且支持变量的运算。

看下下面的例子

<style scoped lang="scss">
    $Len:100px;
    .class_A {
        width: $Len;
        height: 0.6 * $Len;
        
    }
</style>

效果如下:

image.png

更优雅的scss写法

scss中的层级更清晰,更优雅,代码的可读性更高

看下面这个例子

.contain ul {
    border:1px solid black;
    list-style:none;
}

.contain ul:after {
    display:block;
    clear:both;
}

.contain ul li {
    float:left;
}

.contain ul li > a {
    display:inline-block;
    padding:6px 12px;
}

上面的css是一个列表横向排布的例子,但是如果用scss重构

就会是下面的样子

/*scss*/
.contain ul {
    border:1px solid black;
    list-style:none;
    
    li {
        float:left;
    }
    
    li>a {
        display:inline-block;
        padding:6px 12px;
    }
}

.contain ul:after {
    display:block;
    content:"";
    clear:both;
}

&的作用

在scss中,我们可以使用&来选择当前元素的父元素

请看下面的代码

<template>
<div class="class_A">

</div>
</template>

<script setup lang="ts"></script>

<style scoped lang="scss">
$Len:100px;
.class_A {
  width: $Len;
  height: 0.6 * $Len;
  background-color: #646cff;
  &:hover {
    background-color: darkorange;
  }
}
</style>

我们定义了一个div,然后类名是class_A,我们为class_A添加鼠标移动过后颜色改变的特效时,可以通过&来直接选中他。

鼠标移动前后如下

image.png

image.png

结合这些,我们可以对原生css的组合选择器进行简化书写,具体大家可以思考一下。

比如这样

div >{ 
    a {
        color: red;
    }
}

函数式编写scss

scss提供了函数式编写的方案,想象一下下面的场景,我们需要定义三个方块,分别是红色,蓝色,和黄色,大小并不相同,同时每个方块鼠标移过后都会有一个暗淡的效果,我们应该如何去书写呢?

先来看一下原生的css

<template>
  <div class="class_A">

  </div>
  <div class="class_B">

  </div>
  <div class="class_C">

  </div>
</template>

<script setup lang="ts"></script>

<style scoped lang="scss">
.class_A {
  margin: 10px;
  width: 100px;
  height: 60px;
  background-color: red;
}
.class_A:hover {
  opacity: 0.6;
  transition: all 0.6s;
}

.class_B {
  margin: 10px;
  width: 80px;
  height: 48px;
  background-color: blue;
}
.class_B:hover {
  opacity: 0.6;
  transition: all 0.6s;
}

.class_C {
  margin: 10px;
  width: 60px;
  height: 36px;
  background-color: yellow;
}
.class_C:hover {
  opacity: 0.6;
  transition: all 0.6s;
}
</style>

三种方块不同大小,颜色,同时鼠标移动会有一个特效

image.png

接下来让我们用scss做一个重构

在此之前让我们来先介绍一下scss函数的用法

我们通过@mixin声明一个函数,然后通过@include来使用

@mixin fun($w) {
      // 定义了一个函数fun,接受一个参数
}

好了,我们正式开始重构我们的代码

<template>
  <div class="class_A">

  </div>
  <div class="class_B">

  </div>
  <div class="class_C">

  </div>
</template>

<script setup lang="ts"></script>

<style scoped lang="scss">
@mixin fun($w,$h,$bg) {
  margin: 10px;
  width: $w;
  height: $h;
  background-color: $bg;
  &:hover {
    opacity: 0.6;
    transition: all 0.6s;
  }
}
.class_A {
  @include fun(100px,60px,red);
}
.class_B {
  @include fun(80px,48px,blue);
}
.class_C {
  @include fun(60px,36px,yellow);
}
</style>

同样的效果,更少的代码,更优雅的写法,更简洁的代码风格,更高的可读性和可维护性。

image.png

而在很多耦合度更高的情况下,这种写法能更大的提升代码的可维护性和可读性。

@each , @if , @else if , @else的学习

在@each变量的定义,其中包含的每个项目的列表中的值。

而其他的三个很明显是流程判断的指令,话不多说,我们继续使用上面的代码重构我们的需求。

先分析下我们的class,有A,B,C三种不同的状态。所以我们开始操作,请相信我这是最后一遍重构了。

<template>
  <div class="class_A">

  </div>
  <div class="class_B">

  </div>
  <div class="class_C">

  </div>
</template>

<script setup lang="ts"></script>

<style lang="scss">
@mixin fun($w,$h,$bg) {
  margin: 10px;
  width: $w;
  height: $h;
  background-color: $bg;
  &:hover {
    opacity: 0.6;
    transition: all 0.6s;
  }
}
@each $state in  A , B , C  {
  .class_#{$state} {
    @if(#{$state} == A) {
      @include fun(100px,60px,red);
    }
    @else if(#{$state} == B) {
      @include fun(80px,48px,blue);
    }
    @else {
      @include fun(60px,36px,yellow);
    }
  }
}
</style>

好耶,还是一样的。不过代码高级,优雅了太多啦。

image.png

面向对象

最后再说说scss中的继承的问题,我们可以向面向对象一样去继承。

我们通过@extend来继承一个类,这个类可以是css中的class,也可以是我们定义的基类。

基类的定义:

%base-class {
    //...
}

然后我们可以定义一个类来继承这个基类

.class_1 {
    @extend %base-class;
    // 也可以再写点,或者改基类的一些属性
}

我们甚至可以再定义一个类去继承class_1,这也是完全可以的。


.class_1--child {
    @extend .class_1;
    // 继续写点也行,改点基类属性也行
}

最后

入门scss之后,我们以后就正式开始组件的封装了。

相关文章
|
前端开发 JavaScript 安全
|
5月前
|
设计模式 JavaScript 前端开发
Vue.js 组件设计模式:在前端热潮中找到归属感,打造可复用组件库,开启高效开发之旅!
【8月更文挑战第22天】Vue.js 以其高效构建单页应用著称,更可通过精良的组件设计打造可复用组件库。组件应职责单一、边界清晰,如一个显示文本并触发事件的按钮组件,通过 props 传递标签文本,利用插槽增强灵活性,允许父组件注入动态内容。结合 CSS 预处理器管理和封装独立模块,配以详尽文档,有效提升开发效率及代码可维护性。合理设计模式下,组件库既灵活又强大,持续实践可优化项目工作流。
66 1
|
缓存 JavaScript 前端开发
深入探讨Vue.js:从基础到高级(最佳实践)(2)
Vue CLI:官方的脚手架工具,用于快速搭建Vue项目。 Vue Devtools:浏览器扩展,用于调试Vue.js应用程序。 Vue Router:官方的路由管理库,用于构建SPA。 Vuex:官方的状态管理库,用于管理应用程序状态。 axios:用于处理HTTP请求的库,与Vue结合使用非常方便。
120 0
|
存储 JavaScript 前端开发
|
JavaScript 前端开发 API
Vue.js入门指南:从基础到进阶,掌握现代JavaScript框架的核心概念与高级特性(2W字小白教程)
Vue.js入门指南:从基础到进阶,掌握现代JavaScript框架的核心概念与高级特性(2W字小白教程)
192 0
|
JavaScript 前端开发 测试技术
从0搭建Vue3组件库(十二):引入现代前端测试框架 Vitest
从0搭建Vue3组件库(十二):引入现代前端测试框架 Vitest
515 0
|
前端开发 测试技术
从0搭建Vue3组件库(一): 开篇
从0搭建Vue3组件库(一): 开篇
398 0
|
编解码 JavaScript 前端开发
Vue项目实战——【基于 Vue3.x + Vant UI】实现一个多功能记账本(项目演示、涉及知识点、源码分享)
Vue项目实战——【基于 Vue3.x + Vant UI】实现一个多功能记账本(项目演示、涉及知识点、源码分享)
298 0
|
前端开发 容器
前端封装库/工具库的组件库之antd
在现代前端开发中,UI 组件库是一个非常重要的组成部分。其中,Ant Design 是一个备受欢迎的 React UI 组件库。
570 0