技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-3.使用flex布局并开始搭建web端

简介: lex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间。其中justify-content(水平方向对齐)属性和align-content(垂直方向对齐)属性更方便地解决元素的对其、分布方式
1.用sass工具定义flex布局样式
flex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间。
其中 justify-content(水平方向对齐)属性align-content(垂直方向对齐)属性更方便地解决元素的对其、分布方式
在这里插入图片描述
在这里插入图片描述
具体在什么场景如何得到效果大家去链接中测试。

sass工具定义:

// flex布局
.d-flex{
    display: flex;
}
$flex-jc: (
    start: flex-start,
    end: flex-end,
    center: center,
    between: space-between,
    around: space-around,
);
@each $key,$value in $flex-jc {
    .jc-#{$key} {
        justify-content: $value;
    }
}
$flex-ac: (
    start: flex-start,
    end: flex-end,
    center: center,
    between: space-between,
    around: space-around,
    stretch: stretch,
);
@each $key,$value in $flex-ac {
    .ac-#{$key} {
        align-content: $value;
    }
}

在这里插入图片描述
另外,如果遇到需要让几个灵活项目横、纵向排列,可以用到flex-derection:

.flex-column{
    // 灵活的项目将垂直显示,正如一个列一样。
    flex-direction: column;
}

在这里插入图片描述
在这里插入图片描述

2.利用sass生成的css搭建web端

(1)添加web端路由
具体路由操作见admin路由设置
与admin端相同,直接给web端添加路由:

cd web 
vue add router

选择no,使用普通路由
在这里插入图片描述
安装完成后,web端文件自动配置,同时页面出现了路由:
在这里插入图片描述
在这里插入图片描述
我们不在所有页面使用固定路由,所以删掉vue默认设置的路由。
在这里插入图片描述
新建主入口页面Main.vue,将Main组件当作主页面,把Home.vue视为首页组件,通过路由将Home.vue作为子组件引入到Main.vue:
在这里插入图片描述
在这里插入图片描述
待页面样式完善后,添加其他页面路由。
(2)使用sass生成的css优化界面
在这里插入图片描述
给我们需要添加效果的模块直接添加类名即可。
我的页面,其中首页为Home.vue,技能学习为Skill.vue,文章中心为Article.vue:
在这里插入图片描述
Main.vue

<template>
    <div>
        <div class="topbar py-2 px-3 d-flex ac-center">
            <img src="../assets/logo.png" height="50">
            <div class="px-2 flex-1">
                <div class="text-black fs-lg pt-2">八方设计</div>
                <div class="text-gray fs-xxs pt-2">用设计挖掘梦想</div>
            </div>
            <div class="py-3">
                <button class="btn bg-primary text-white">用户登录</button>
            </div>
        </div>
        <div class="bg-primary pt-3 pb-2">
            <div class="nav d-flex text-white jc-around">
                <div class="nav-item">
                    <!-- 导航使用路由的active-class,根据所在路由位置为标签添加类名,同时在style.scss中设置active类名的样式 -->
                    <!-- extra属性与active-class配合使用,更精确找到路由位置,若不加则会认为/skill在/内(即技能学习在首页内部),二者都会被赋予active类名 -->
                    <router-link class="nav-link" tag="div" to="/" active-class="active" exact>首页</router-link>
                </div>
                <div class="nav-item">
                    <router-link class="nav-link" tag="div" to="/skill" active-class="active" exact>技能学习</router-link>
                </div>
                <div class="nav-item">
                    <router-link class="nav-link" tag="div" to="/article" active-class="active" exact>文章中心</router-link>
                </div>
            </div>
        </div>

        <!-- 路由组件 -->
        <router-view></router-view>
    </div>
</template>

<script>
export default {
    
}
</script>

<style>
    .fs-xxs{
        letter-spacing: 3px;
    }
    .fs-lg{
        letter-spacing: 3px;
    }
    .topbar{
        /* 吸顶效果 */
        position: sticky;
        top: 0;
        z-index: 999;
    }
</style>

style.scss

// 规范样式

* {
    // 避免margin/padding等将页面向外扩充,加入border-box后页面像内部挤压
    box-sizing: border-box;
    // 取消鼠标移入等高亮样式
    outline: none;
}

html {
    // 设置默认字体大小
    font-size: 13px;
}

body {
    // 设置body默认

    // 去除body边框
    margin: 0;
    // 设置字体:所有计算机自带字体,苹果电脑自带字体,非衬线字体
    font-family: Arial, Helvetica, sans-serif;
    // 行距
    line-height: 1.2rem;
    // 背景颜色
    background: #f5f5f5;
}

a {
    color: #999;
}

ul, li{
    list-style: none;
}


// colors常用颜色
$colors: (
    // 主色
    "primary": #a80506,
    // 辅色
    "auxiliary": #054ea8,
    // 点缀色
    "Embellishment":#db9e3f,

    // 白色
    "white": #fff,
    // 黑色
    "black": #000,
    // 灰色
    "gray": #777,
);
@each $colorKey, $color in $colors {
    // 文字颜色
    .text-#{$colorKey} {
        color: $color;
    }
    // 背景颜色
    .bg-#{$colorKey} {
        background: $color;
    }
}

// text常用文本
@each $var in (left, center, right) {
    .text-#{$var}{
        text-align: $var;
    }
}
// 使用px to rem插件设置默认字体大小为13px
// 设置基础字体大小
$base-font-size: 1rem;
// 根据基础字体大小设置字体大小
$font-size: (
    // 使用px to rem插件,alt + z 转化px到rem
    // xs为6px
    xxs: 0.4615,
    // xs为10px
    xs: 0.7692,
    // sm为12px
    sm: 0.9231,
    // md为13px
    md: 1,
    // lg为14px
    lg: 1.0769,
    // xl为16px
    xl: 1.2308,
);
@each $sizeKey, $size in $font-size {
    // 文字颜色
    .fs-#{$sizeKey} {
        font-size: $size * $base-font-size;
    }
}


// flex布局
.d-flex{
    display: flex;
}
.flex-1{
    flex: 1;
}
.flex-column{
    // 灵活的项目将垂直显示,正如一个列一样。
    flex-direction: column;
}
$flex-jc: (
    start: flex-start,
    end: flex-end,
    center: center,
    between: space-between,
    around: space-around,
);
@each $key,$value in $flex-jc {
    .jc-#{$key} {
        justify-content: $value;
    }
}
$flex-ac: (
    start: flex-start,
    end: flex-end,
    center: center,
    between: space-between,
    around: space-around,
    stretch: stretch,
);
@each $key,$value in $flex-ac {
    .ac-#{$key} {
        align-content: $value;
    }
}


// 间距spacing
// bootstrap中,mt-1 -> margin-top: 1rem, pb-2 -> padding-bottom: 2rem

// 类型
$spacing-types: (m: margin, p: padding);
// 方向
$spacing-directions: (t: top, r: right, b: bottom, l:left);
// 尺寸
$base-spacing-size: 1rem; // 基础尺寸
$spacing-sizes: (0: 0, 1: 0.25, 2: 0.5, 3: 1, 4: 1.5, 5: 3); // 基础尺寸为准的倍数
@each $typeKey, $type in $spacing-types {
    @each $directionKey, $direction in $spacing-directions {
        @each $sizeKey, $size in $spacing-sizes {
            // 样版: .mt-1 { margin-top: 0.25rem }
            .#{$typeKey}#{$directionKey}-#{$sizeKey} {
                #{$type}-#{$direction}: $size * $base-spacing-size;
            }
        }
    }
}
// m-1, p-1等只需要嵌套类型变量$spacing-directions和尺寸变量$spacing-sizes
@each $typeKey, $type in $spacing-types {
    @each $sizeKey, $size in $spacing-sizes {
        // 样版: .mt-1 { margin-top: 0.25rem }
        .#{$typeKey}-#{$sizeKey} {
            #{$type}: $size * $base-spacing-size;
        }
    }
}

// 水平、垂直方向边距
@each $typeKey, $type in $spacing-types {
    @each $sizeKey, $size in $spacing-sizes {
        // mx-1,px-1
        .#{$typeKey}x-#{$sizeKey} {
            #{$type}-left: $size * $base-spacing-size;
            #{$type}-right: $size * $base-spacing-size;
        }
        // my-1,py-1
        .#{$typeKey}y-#{$sizeKey} {
            #{$type}-top: $size * $base-spacing-size;
            #{$type}-bottom: $size * $base-spacing-size;
        }
    }
}

// button
.btn{
    border: none;
    border-radius: 0.1538rem;
    font-size: map-get($font-size, 'sm') * $base-font-size;
    padding: 0.4rem 0.6rem;
}

// nav-border
.nav{
    .nav-item{
        border-bottom: 3px solid transparent;
        padding-bottom: 0.2rem;
        // 符号&代表上一层本身
        .active{
            border-bottom: 2px solid #fff;
        }
    }
}
相关文章
|
2月前
|
前端开发 算法 Java
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
132 1
|
2月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
Flex 布局 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。 一、Flex 布局是什么? Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
272 1
|
6月前
|
设计模式 容器
13.HarmonyOS流式卡片列表实现指南:Flex多行布局详解
在现代移动应用开发中,流式卡片列表是一种常见且实用的UI设计模式。它能够自适应屏幕宽度,在有限空间内高效展示多个内容项。本教程将详细讲解如何使用HarmonyOS的ArkUI框架中的Flex组件实现一个灵活的流式卡片列表,重点关注多行布局与对齐策略的应用。
228 2
|
6月前
|
开发者 UED 容器
07.精通HarmonyOS Flex对齐:从基础到高级布局技巧(上)
在HarmonyOS Next的ArkUI框架中,Flex容器提供了强大而灵活的对齐系统,使开发者能够精确控制子元素在容器中的排列方式。掌握这些对齐技术,是构建专业级用户界面的关键。
215 0
|
6月前
|
UED 容器
5.HarmonyOS Next开发宝典:掌握Flex布局的艺术
Flex布局(弹性布局)是HarmonyOS Next中最强大的布局方式之一,它提供了一种更加高效、灵活的方式来对容器中的子元素进行排列、对齐和分配空间。无论是简单的居中显示,还是复杂的自适应界面,Flex布局都能轻松应对。
233 0
|
6月前
|
UED 容器
10.HarmonyOS Next布局进阶:嵌套Flex容器与空间分配策略
在HarmonyOS Next的ArkUI框架中,Flex布局是构建用户界面的核心技术之一。通过嵌套使用Flex容器,我们可以创建复杂而灵活的界面结构,满足各种应用场景的需求。本教程将深入探讨如何在HarmonyOS Next中使用嵌套Flex容器实现复杂布局,以及如何合理分配和控制空间。
187 0
|
9月前
|
开发者 容器
鸿蒙开发:弹性布局Flex
在实际的开发中,需要掌握主轴与交叉轴的关系、换行规则及子元素属性,同时注意性能与兼容性问题,还有一点,Flex组件在渲染时存在二次布局过程,因此在对性能有严格要求的场景下建议使用Column、Row代替。
254 10
鸿蒙开发:弹性布局Flex
Bootstrap5 Flex(弹性)布局4
排序:.order 类可设置弹性子元素的排序,范围从 .order-1 至 .order-12,数字越小优先级越高。外边距:.ms-auto 和 .me-auto 分别用于设置子元素的右侧和左侧外边距为 auto。包裹:.flex-nowrap(默认)、.flex-wrap 和 .flex-wrap-reverse 用于控制弹性容器中的子元素是否换行及换行方向。
Bootstrap5 Flex(弹性)布局6
使用 `.align-self-*` 类可控制指定子元素的对齐方式,包括 `.align-self-start`, `.align-self-end`, `.align-self-center`, `.align-self-baseline`, 和 `.align-self-stretch`。示例代码展示了如何在一个弹性布局中应用这些类,以实现不同设备上的响应式设计。
Bootstrap5 Flex(弹性)布局5
使用 .align-content-* 控制多行子元素在垂直方向上的堆叠方式,如 .align-content-start、.align-content-center 等。对于单行子元素,使用 .align-items-* 控制对齐,例如 .align-items-start、.align-items-center 等。示例代码展示了不同对齐效果的应用。