Material Design风格神框架vuetify 学习笔记(十三) 动画 弹性布局

一. 动画

1. 过度样式

(1). 缩放过渡动画 scale-transition
<template>
  <div>
    <v-container grid-list-xs>
      <div class="text-center mb-4">
        <v-btn color="primary" @click="alert = !alert"> Toggle </v-btn>
      </div>
      <v-alert
        :value="alert"
        color="pink"
        dark
        icon="mdi-fingerprint"
        transition="scale-transition"
      >
        <p>
          猎鹰9号(Falcon 9)火箭是美国SpaceX公司研制的可回收式中型运载火箭。
        </p>
        <p>猎鹰9号于2010年6月4日完成首次发射,于2015年12月21日完成首次回收。</p>
        <p>
          美国东部时间2021年4月23日5时49分,SpaceX载人龙飞船搭乘猎鹰9号火箭从佛罗里达州肯尼迪航天中心发射升空,执行商业载人航天任务Crew-2,送4名宇航员前往国际空间站,开展为期6个月的任务。飞船计划于4月24日5时10分对接空间站。
        </p>
      </v-alert>
    </v-container>
  </div>
</template>

<script>
export default {
  data() {
    return { alert: true };
  },
};
</script>
(2). fab过渡动画 fab-transition
transition="fab-transition"
(3). 淡入淡出 fade-transition
transition="fade-transition"
(4). X轴滚动
transition="scroll-x-transition"
(5). X轴反向滚动
transition="scroll-x-reverse-transition"
(6). Y轴滚动
transition="scroll-y-transition"
(7). Y轴反向滚动
transition="scroll-y-reverse-transition"
(8). X轴滑动

滑动和滚动感觉上没有太大差别, 除了方向稍微不同

transition="slide-x-transition"
(9). X轴反向滑动
transition="slide-x-reverse-transition"
(10). Y轴滑动
transition="slide-x-transition"
(11). Y轴反向滑动
transition="slide-y-reverse-transition"

二. 弹性布局

使用响应的flexbox实用程序通过对齐、排列等方式控制flex容器的布局, 采用Flex布局的元素,称为Flex容器(flex container),简称”容器”。它的所有子元素自动成为容器成员,称为Flex项目(flex item),简称”项目”。

1. 启用flexbox

你可以将任何元素转换为 flexbox 容器并将该元素的 子元素 转成 flex 元素.

<template>
  <div class="ma-4">
    <div class="d-flex flex-wrap text-center">
      <v-sheet
        color="green white--text"
        outlined
        min-width="200"
        v-for="n in 24"
        :key="n"
        class="ma-1"
      >
        DNA的第{{ n }}本生命之书
      </v-sheet>
    </div>
  </div>
</template>

2. 基于断点的flex

d-flex
d-inline-flex
d-sm-flex
d-sm-inline-flex
d-md-flex
d-md-inline-flex
d-lg-flex
d-lg-inline-flex
d-xl-flex
d-xl-inline-flex

3. flex对齐轴方向

flex-row (默认) 行对齐
flex-row-reverse 行反向对齐
flex-column 列对齐
flex-column-reverse 列反向对齐

如: 行反向对齐

<v-row class="d-flex flex-row-reverse text-center">

如: 列对齐
IE11 和 Safari 可能存在列方向的问题

<v-row class="d-flex flex-column text-center">

如: 列反向对齐
IE11 和 Safari 可能存在列方向的问题

<v-row class="d-flex flex-column-reverse text-center">
当然行列对齐也有断点
.flex-row
.flex-row-reverse
.flex-column
.flex-column-reverse
.flex-sm-row
.flex-sm-row-reverse
.flex-sm-column
.flex-sm-column-reverse
.flex-md-row
.flex-md-row-reverse
.flex-md-column
.flex-md-column-reverse
.flex-lg-row
.flex-lg-row-reverse
.flex-lg-column
.flex-lg-column-reverse
.flex-xl-row
.flex-xl-row-reverse
.flex-xl-column
.flex-xl-column-reverse

4. 横轴对齐子类justify

Flex 横轴对齐的子类 justify子类, 默认情况下修改控制x轴上的flex项目

.justify-start  顶头
.justify-end   顶尾
.justify-center   居中
.justify-space-between  间隔均分
.justify-space-around    间隔环绕
.justify-sm-start
.justify-sm-end
.justify-sm-center
.justify-sm-space-between
.justify-sm-space-around
.justify-md-start
.justify-md-end
.justify-md-center
.justify-md-space-between
.justify-md-space-around
.justify-lg-start
.justify-lg-end
.justify-lg-center
.justify-lg-space-between
.justify-lg-space-around
.justify-xl-start
.justify-xl-end
.justify-xl-center
.justify-xl-space-between
.justify-xl-space-around

5. 纵轴对齐子类align

Flex 纵轴对齐的子类 align子类, 默认情况下修改控制y轴上的flex项目

.align-start 顶头
.align-end 顶尾
.align-center 居中
.align-baseline 基准线
.align-stretch 浏览器默认
.align-sm-start
.align-sm-end
.align-sm-center
.align-sm-baseline
.align-sm-stretch
.align-md-start
.align-md-end
.align-md-center
.align-md-baseline
.align-md-stretch
.align-lg-start
.align-lg-end
.align-lg-center
.align-lg-baseline
.align-lg-stretch
.align-xl-start
.align-xl-end
.align-xl-center
.align-xl-baseline
.align-xl-stretch

6. 堆叠方式

.flex-nowrap  不换行
.flex-wrap  换行(默认)
.flex-wrap-reverse 反向换行
flex-nowrap
flex-wrap
flex-wrap-reverse
.flex-sm-nowrap
.flex-sm-wrap
.flex-sm-wrap-reverse
.flex-md-nowrap
.flex-md-wrap
.flex-md-wrap-reverse
.flex-lg-nowrap
.flex-lg-wrap
.flex-lg-wrap-reverse
.flex-xl-nowrap
.flex-xl-wrap
.flex-xl-wrap-reverse

7. 自身对齐 (应用在flex item上)

Flex 纵轴对齐的子类 align-self子类, 默认情况下修改控制x轴上的flex项目

.align-self-start
.align-self-end
.align-self-center
.align-self-baseline
.align-self-auto
.align-self-stretch
.align-self-sm-start
.align-self-sm-end
.align-self-sm-center
.align-self-sm-baseline
.align-self-sm-auto
.align-self-sm-stretch
.align-self-md-start
.align-self-md-end
.align-self-md-center
.align-self-md-baseline
.align-self-md-auto
.align-self-md-stretch
.align-self-lg-start
.align-self-lg-end
.align-self-lg-center
.align-self-lg-baseline
.align-self-lg-auto
.align-self-lg-stretch
.align-self-xl-start
.align-self-xl-end
.align-self-xl-center
.align-self-xl-baseline
.align-self-xl-auto
.align-self-xl-stretch

8. 自动边距 (应用在flex item上)

  • mr-auto : 右侧自动边距
<template>
  <div class="ma-4">
    <v-row class="d-flex">
      <v-sheet
        color="green white--text"
        outlined
        width="200"
        height="100"
        v-for="n in 24"
        :key="n"
        class="ma-1 mr-auto"
      >
        DNA的第{{ n }}本生命之书
      </v-sheet>
    </v-row>
  </div>
</template>
  • ml-auto : 左侧自动边距
<template>
  <div class="ma-4">
    <v-row class="d-flex">
      <v-sheet
        color="green white--text"
        outlined
        width="200"
        height="100"
        v-for="n in 24"
        :key="n"
        class="ma-1 ml-auto"
      >
        DNA的第{{ n }}本生命之书
      </v-sheet>
    </v-row>
  </div>
</template>

9. 自定义排序

<template>
  <div class="ma-4">
    <v-row class="d-flex">
      <v-sheet dark min-width="200" class="ma-1 order-2"> DNA的第1本生命之书 </v-sheet>
      <v-sheet dark min-width="200" class="ma-1 order-0"> DNA的第2本生命之书 </v-sheet>
      <v-sheet dark min-width="200" class="ma-1 order-1"> DNA的第3本生命之书 </v-sheet>
    </v-row>
  </div>
</template>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容