搭建自己的组件库<2>dialog 组件

目录

设置title

插槽显示

控制宽高

关闭对话框

transition实现动画

引入深度选择器


同样创建组件dialogue.vue后全局注册

dialogue模版:

<template>
    <!-- 对话框的遮罩 -->
    <div class="miao-dialog_wrapper">
        <!-- 真的对话框 -->
        <div class="miao-dialog">

            <div class="miao-dialog_header">
                <span class="miao-dialog_title">提示</span>
                <button class="miao-dialog_headerbtn">
                    <i class="miao-icon-close"></i>
                </button>
            </div>
            <div class="miao-dialog_body">
                <span>这是一段信息</span>
            </div>
            <div class="miao-dialog_footer">
                <miao-button>取消</miao-button>
                <miao-button type="primary">确定
                </miao-button>
            </div>
        </div>
    </div>
</template>

设置title

第一步,设置title为传入的参数

app.vue里:

<miao-dialog title="温馨提示"></miao-dialog>

dialogue.vue里

props:{
    title:{
        type:String,
        default:'提示'

    }
}

插槽显示

第二步用插槽显示

这在dialogue.vue里

<slot name="title">
                    <span class="miao-dialog_title">{{ title }}</span>
                </slot>
                <!-- 把这个class包在插槽里意思是有插槽显示插槽,没插槽显示里面的title文字 -->

在app.vue里

<miao-dialog>
  <template v-slot:title>
   <h3>我是变化</h3>
  </template>
</miao-dialog>

这样如果title啥都不传显示默认值,并且通过slot可以设置传入是h3还是h2等格式

控制宽高

通过style里的width和top控制dialog的宽度和距离顶部的距离

app.vue

<miao-dialog width="40%" top="10px">
      
    </miao-dialog>

dialog.vue

<div class="miao-dialog" :style="{width:width,marginTop:top}">

然后设置

width:{
        type: String,
        default: '50%'
    },
    top:{
        type: String,
        default: '15vh'
        // 类似于15%
    }

然后通过插槽控制body部分

app.vue

<miao-dialog width="40%" top="10px">
      <ul>
        <li>1</li>
        <li>2</li>
      </ul>
    </miao-dialog>

dialog.vue

<div class="miao-dialog_body">
                <!-- 默认插槽  -->
                <slot></slot>
               

            </div>

接下来控制footer,footer里显示两个按钮,但是底部两个按钮也是想传才传

所以也添加slot控制

app.vue里:

<miao-dialog width="40%" top="10px">
      <ul>
        <li>1</li>
        <li>2</li>
      </ul>
      <template v-slot:footer>
        <miao-button type="primary">确定</miao-button>
        <miao-button>取消</miao-button>
      </template>
    </miao-dialog>

关闭对话框

dialog.vue里

关闭部分:

除了按钮之外点击对话框的icon❎也应该关闭他:

<button class="miao-dialog_headerbtn" @click="handleClose">
                    <i class="miao-icon-close"></i>
                </button>

点击子组件dialogue.vue不能直接修改父组件数据

所以在函数handleclose里触发父组件

methods:{
    handleClose(){
        // this.visible=false,不行避免直接修改props
        //得让父组件改,应该触发事件
        this.$emit('close',false)
    }
}

在app.vue里:

<miao-dialog width="40%" top="10px" :visible="visible" @close="close">
      <ul>
        <li>1</li>
        <li>2</li>
      </ul>
      <template v-slot:footer>
        <miao-button type="primary" @click="visible=false">确定</miao-button>
        <miao-button @click="visible=false">取消</miao-button>
      </template>
    </miao-dialog>

@ close="close"

close(value){
this.visible=value
},

这样点击该icon就能关闭对话框了

此外,需要点击遮罩层也能关闭对话框,但是对话框内部也包括在遮罩层里,所以通过@click.self 阻止冒泡

或者通过sync语法糖,(子组件希望修改父组件的visible)

使用方法:

在子组件里:

demo.vue

<button @click="fn">aaa</button>
methods:{
    fn(){
        this.$emit('update:money',30)
        this.$emit('update:visible', true)
    }
    
}

父组件里:
 

 <demo :visible.sync="visible" :money.sync="money"></demo>

不用再写函数注册事件了,比如省去了

update:money(value){this.money=value}

没有改变单向数据流,只是让父组件使用更简单

transition实现动画

通过transition实现动画(千万记得.5s

<transition  name="aa">
      <div v-show="visible">我是文本</div>
    </transition>

第一种写动画的css方式:

.aa-enter{
  opacity: 0;
}
// aa对应name属性,enter显示前,to显示后,active显示中
.aa-enter-to{
  opacity: 1;
}
.aa-enter-active{
  transition: all .5s;
}


// 离开同样三个类名
.aa-leave{
  opacity: 1;
}
.aa-leave-to{
  opacity: 0;
}

.aa-leave-active{
  transition: all .5s
}

第二种写动画的方式(采用)

.aa-enter{
  opacity: 0;
}
// aa对应name属性,enter显示前,to显示后,active显示中
.aa-enter-to{
  opacity: 1;
}
.aa-enter-active{
  transition: all .5s;
}


// 离开同样三个类名
.aa-leave{
  opacity: 1;
}
.aa-leave-to{
  opacity: 0;
}

.aa-leave-active{
  transition: all .5s
}

css里前面那个aa是变化的根据name来,后面的是固定的

接下来让整个dialogue有动画:

.dialog-fade-enter-active {
    animation: fade .3s;
}

.dialog-fade-leave-active {
    animation: fade .3s reverse;
}

@keyframes fade {
    0% {
        opacity: 0;
        transform: translateY(-20px);
        // 负值向上移动

    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
.miao-button{
    margin-left:8px
}

scoped会给当前组件的模版中的所有元素都添加一个随机的属性

scoped会给当前组件中所有样式也添加一个对应的属性选择器

引入深度选择器

当写了style scoped时候,不会有随机属性选择器

深度选择器 scss里 ::v-deep  less里 /deep/
css >>>
官网链接:

Scoped CSS | Vue Loader

详细代码:

GitHub - Alicca-miao/component-library-vue-ui-Contribute to Alicca-miao/component-library-vue-ui- development by creating an account on GitHub.icon-default.png?t=N7T8https://github.com/Alicca-miao/component-library-vue-ui-

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/695033.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python如何输入回车

Python默认遇到回车的时候&#xff0c;输入结束。所以我们需要更改这个提示符&#xff0c;在遇到空行的时候&#xff0c;输入才结束。 raw_input就是从标注输入读取输入&#xff0c;输入的是什么就是什么。 文档解释&#xff1a; The function then reads a line from input,…

debian系统apt 国内安装源

debian系统apt 国内安装源&#xff1a; 国内阿里镜像源&#xff1a; deb http://mirrors.aliyun.com/debian stable main non-free contrib deb-src http://mirrors.aliyun.com/debian stable main non-free contrib 打开源文件位置&#xff1a;/etc/apt/sources.list,原来的内…

《经典图论算法》广度优先搜索

摘要&#xff1a; 1&#xff0c;广度优先搜索介绍 2&#xff0c;广度优先搜索的解题步骤 3&#xff0c;广度优先搜索的代码实现 1&#xff0c;广度优先搜索介绍 广度优先搜索(Breadth-first search&#xff0c;BFS)&#xff0c;又称宽度优先搜索&#xff0c;简单的说&#xff0…

知识工作者如何在工作中使用大模型?

自 2022 年 11 月 OpenAI 发布 ChatGPT 以来&#xff0c;人们对生成式人工智能&#xff08;GenAI&#xff0c;以下简称“生成式AI”&#xff09;的兴趣激增&#xff0c;同时也对其安全性表示担忧。 &#xff08;译者注&#xff1a;生成式人工智能&#xff0c;即用 AI 生成文本…

大模型常用推理参数工作原理

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 do_sample do_sample 参数控制是否使用采样…

QQ号码采集软件

寅甲QQ号码采集软件, 一款采集QQ号、QQ邮件地址&#xff0c;采集QQ群成员、QQ好友的软件。可以按关键词采集&#xff0c;如可以按地区、年龄、血型、生日、职业等采集。采集速度非常快且操作很简单。

抽象的java入门1.3.2

前言&#xff1a; 全新版本的函数&#xff08;方法&#xff09;定义&#xff0c;更简单 1.优化了验证过程&#xff0c;直击本质 2.新增目前一图流 正片&#xff1a; 函数的结构可以分为三部分&#xff1a;函数名&#xff0c;参数&#xff0c;函数体 一生二&#xff0c;二生…

扩散模型Stable Diffusion

扩散模型构成 Text Encoder(CLIPText) Clip Text为文本编码器。以77 token为输入&#xff0c;输出为77 token 嵌入向量&#xff0c;每个向量有768维度。 Diffusion(UNetScheduler) 在潜在空间中逐步处理扩散信息。以文本嵌入向量和由噪声组成的起始多维数组为输入&#xff0c…

gcc源码分析 词法和语法分析

gcc源码分析 词法和语法分析 一、输入参数相关1、命令行到gcc二、词法与语法分析1、词法分析1.1 struct cpp_reader1.2 struct tokenrun/struct cpp_token/lookahead字段1.3 struct ht2.1 语法符号相关的结构体c_token定义如下:2.2在语法分析中实际上有多个API组成了其接口函数…

产品成功的关键:构建高效运作的系统

在如今竞争激烈的市场环境中&#xff0c;一个产品要想脱颖而出&#xff0c;不仅仅需要独特的创意和优质的功能&#xff0c;更需要建立一套高效运作的系统。这个系统包括结果的具体化、达成路径的明确以及持续执行迭代并形成习惯等多个环节。下面&#xff0c;我们将结合具体的案…

中国现在最厉害的书法家颜廷利:东方伟大思想家哲学家教育家

中国书法界名人颜廷利教授&#xff0c;一位在21世纪东方哲学、科学界及当代中国教育领域内具有深远影响力的泰斗级人物&#xff0c;不仅以其深厚的国学修为和对易经姓名学的独到见解著称&#xff0c;还因其选择在济南市历城区的龙泉大街以及天桥区的凤凰山庄与泉星小区等地设立…

副业赚钱:如何避开陷阱,实现真正的财务自由

嗨&#xff0c;我是兰若&#xff0c;在这个时代&#xff0c;副业已经成为许多人追求财务自由的途径。但是&#xff0c;你在网上看到的许多副业广告实际上可能让你陷入更糟糕的境地。今天&#xff0c;我们就来揭开这些副业的真相&#xff0c;并分享一些真正有潜力的副业选择&…

SpringBoot——整合WebSocket长连接

目录 WebSocket 项目总结 新建一个SpringBoot项目 pom.xml WebSocketConfig配置类 TestWebSocketEndpoint服务端点类 socket.html客户端 IndexController控制器 SpringbootWebsocketApplication启动类 测试客户端和服务端如何使用WebSocket进行连接和通信 WebSocket S…

Spark参数配置不合理的情况

1.1 内存设置 &#x1f4be; 常见的内存设置有两类&#xff1a;堆内和堆外 &#x1f4a1; 我们作业中大量的设置 driver 和 executor 的堆外内存为 4g&#xff0c;造成资源浪费 &#x1f4c9;。 通常 executor 堆外内存在 executor.cores1 的时候&#xff0c;1g 足够了&…

C语言 树与二叉树基础部分

树与二叉树基础部分 树的基础概念二叉树的性质二叉树的遍历前序遍历中序遍历后序遍历层序遍历根据遍历结果恢复二叉树 二叉树的创建第一种第二种 二叉树的其他典型操作查找指定元素&#xff08;一般二叉树&#xff09;二叉树的高度&#xff08;深度&#xff09;二叉树的拷贝二叉…

BFS实现图的点的层次-java

加强对广度优先搜索的理解&#xff0c;其实就是主要的3个步骤&#xff0c;外加数组模拟单链表是基础&#xff0c;要搞懂。 目录 前言 一、图中点的层次 二、算法思路 1.广度优先遍历 2.算法思路 三、代码如下 1.代码如下&#xff08;示例&#xff09;&#xff1a; 2.读入…

地理信息系统(ArcGIS)在水文水资源、水环境中的实践技术应用及案例分析教程

原文链接&#xff1a;地理信息系统&#xff08;ArcGIS&#xff09;在水文水资源、水环境中的实践技术应用及案例分析教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247606047&idx5&sn8c9701518e13b85d8429186fcfe98ad8&chksmfa821ef8cdf597ee7a8a1…

数据加密验签机的工作原理

数据加密验签机&#xff0c;作为网络安全领域的关键设备&#xff0c;其重要性不言而喻。以下是对数据加密验签机的详细介绍&#xff1a; 一、引言 在数字化时代&#xff0c;数据的机密性、完整性和真实性是企业和个人都极为关注的问题。数据加密验签机&#xff0c;正是为了解决…

嘉立创面板制作不规则图案技巧

首先附上效果图展示&#xff1a; 所需软件&#xff1a;嘉立创EDA(专业版)、photoshop、Adobe Illustrator 嘉立创EDA(专业版)&#xff1a; 嘉立创面板绘制很容易上手&#xff0c;只要了解这几个图层的作用便可以做出自己想要的面板。 材料边界层&#xff1a; 代表选⽤的材料…

时隔很久运行苍穹外卖项目,出现很多错误

中途运行了很多其他项目&#xff0c;maven的配置文件还被我修改了一次。导致再次运行苍穹外卖项目出现很多错误。 发现没有办法&#xff0c;把本地的仓库删了个干干净净。然后点击clean发现报错&#xff1a; Cannot access alimaven (http://mavejavascript:void(0);n.aliyun.…