你也想做一个Elemen-ui吧!!!——Blueの前端路
创始人
2024-11-13 09:09:48
0

目录

前言

diglog组件

准备工作:

在diglog.vue中模仿element-ui搭建diglog框架

该组件需要完成的任务:

title

diglog.vue代码:

App.vue代码:

效果:

自定义dialog的宽度和距离顶部的

 App.vue代码:

diglog代码:

效果:

自定义body内容

diglog.vue代码:

App.vue代码:

效果: 

自定义footer内容

diglog.vue代码:

App.vue

效果: 

dialog的显示与隐藏

.sync

定义与原理

使用场景

使用方法

注意事项

实操

第一步:

第二步:

第三步:

效果

结语


前言

    🎈🎈🎈Hello,Hello。这里是Blue,本篇文章我们将在前一篇文章http://t.csdnimg.cn/6atDj的基础上,继续封装组件。该组件为经常用的diglog,让我们来尝试去封装一下吧。希望各位在学习途中可以对组件有更多的理解。🎈🎈🎈

视频推荐:http://【VUE进阶-从0到1搭建UI组件库(1-3)】https://www.bilibili.com/video/BV1nJ411V75nhttps://blog.csdn.net/m0_75148088/article/details/140429791?p=13&vd_source=bb412cc25ca27e171f8e17085daad038 

diglog组件

准备工作:

第一步:

我们先创建一个diglog.vue组件,再在App.vue中进行对diglog的使用 

 第二步:在main.js中去将diglog.vue组件声明为全局

import Diglog from './components/diglog.vue' Vue.component(Diglog.name, Diglog)

在diglog.vue中模仿element-ui搭建diglog框架

  

效果如下:

该组件需要完成的任务:

参数名参数描述参数类型默认值
title对话框标题string提示
width宽度string50%
marginTop与顶部的距离string15vh
visible是否显示dialog(支持sync修饰符)booleanfalse
事件名事件描述
close模态框关闭事件

title

  • 父子组件传值以及props验证

  • 利用{{}}将传入内容渲染上去

diglog.vue代码:
  export default {   name: 'WsDiglog',   props: {     title: {       type: String,       default: '提示'     } } 
App.vue代码:
效果:

自定义dialog的宽度和距离顶部的

 App.vue代码:
diglog代码:
 
效果:

自定义body内容

body内容可能是除span以外的其他内容,比如列表等,所以在这里使用插,并且在这里使用匿名插槽,使用匿名插槽的好处就是在使用时不需要使用template标签指定内容,直接在组件标签下编写内容即可。  

diglog.vue代码:
 
App.vue代码:
        
  • 1
  • 2
  • 3
  • 4
  • 效果: 

    自定义footer内容

    footer中使用slot插槽,使其能够根据用户选择来进行是否需要其他东西  

    diglog.vue代码:

    设置footer插槽,如果没有指定footer插槽,则不显示

         
    App.vue
    效果: 

    dialog的显示与隐藏

    dialog组件的显示与隐藏,需要使用到sync语法糖

    在前端开发中,特别是在使用Vue.js框架时,.sync修饰符是一个非常重要的概念,它主要用于简化父子组件之间数据的双向绑定过程。以下是对.sync修饰符的详细解释:

    .sync
    定义与原理

    .sync修饰符是Vue.js提供的一种语法糖,用于实现父子组件之间的双向数据绑定。在Vue 2.3.0+版本中引入,用于替代之前版本的.sync修饰符(在Vue 2.0.0中作为组件的一个特殊选项存在,但在Vue 2.3.0+中被移除并重新作为修饰符引入)。

    在Vue 3中,.sync修饰符继续存在,但需要注意的是,Vue 3推荐使用v-model的多个参数形式来实现类似的功能,因为v-model在Vue 3中被重新设计以支持自定义组件的双向绑定。不过,.sync修饰符仍然可以作为一种替代方案使用。

    使用场景

    .sync修饰符通常用于以下场景:

    • 当父组件需要向子组件传递一个或多个prop,并希望子组件能够修改这些prop的值时。

    • 子组件在修改prop的值后,需要通知父组件进行更新,以保持数据的一致性。

    使用方法

    在父组件中,使用.sync修饰符绑定prop时,Vue会自动监听子组件触发的update:propName事件,并将接收到的新值赋给绑定的数据项。

       

    在子组件中,当需要修改someProp的值时,通过$emit触发update:someProp事件,并传递新的值。

       
    注意事项
    • .sync修饰符实际上是v-bind的语法糖,它会被扩展为v-bind绑定和v-on监听器的组合。

    • 在Vue 3中,虽然.sync修饰符仍然可用,但推荐使用v-model的多个参数形式来实现双向绑定,因为它提供了更清晰的语义和更灵活的使用方式。

    • 使用.sync修饰符时,需要注意避免在子组件中直接修改prop的值,因为这可能会导致数据流的不清晰和难以追踪的问题。相反,应该通过触发事件来通知父组件进行更新。

    综上所述,.sync修饰符是Vue.js中用于简化父子组件之间双向数据绑定的重要工具,但在使用时需要注意其原理和限制条件。

    实操

    根据上面对于sync语法糖的介绍,我们在dialog显示和隐藏中要进行两种处理

    第一步:

    控制dialog的显示和隐藏,我们首先在子组件中使用v-show对于组建的显示与隐藏进行控制。

    diglog.vue代码:

    ···
    第二步:

    在父组件中使用:visible.sync="visible"向子组件进行传值并且接收子组件回调。

    App.vue的代码:

     
    第三步:

    diglog.vue代码:

     
    效果

    结语

      🎈🎈🎈观众老爷们是否学到如何封装diglog组件了嘛?希望本篇文章对观众老爷能起帮助。🎈🎈🎈

    相关内容

    热门资讯

    黑科技实锤(wepoke透明黑... 黑科技实锤(wepoke透明黑科技)wepoke辅助多久会检测到(wepOke)起初存在有挂(有挂秘...
    黑科技了解!aapoker辅助... 黑科技了解!aapoker辅助(微扑克真的有挂)切实有挂(有挂黑科技ai)-哔哩哔哩1、金币登录送、...
    黑科技计算(wpk最新黑科技)... 黑科技计算(wpk最新黑科技)wpk ai辅助安全吗(wpK)真是真的有挂(有挂详细)-哔哩哔哩1、...
    黑科技安装(wepoke真的有... 黑科技安装(wepoke真的有挂)wepoke透明挂使用教程(wopoker)原本有挂(揭秘有挂)-...
    黑科技ai(wpk最新黑科技)... 黑科技ai(wpk最新黑科技)wpk透明挂(wpK)竟然有挂(证实有挂)-哔哩哔哩1、wpk最新黑科...
    黑科技计算!德州之星辅助(德州... 黑科技计算!德州之星辅助(德州ai软件购买)竟然存在有挂(有挂ai代打)-哔哩哔哩;1、下载好德州之...
    黑科技免费(wpk最新黑科技)... 黑科技免费(wpk最新黑科技)wpk辅助软件(WPK)竟然有挂(有挂方式)-哔哩哔哩1、每一步都需要...
    黑科技新版(wepoke黑科技... 自定义系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想分享给你好...
    黑科技好友!德扑之星系统发牌机... 黑科技好友!德扑之星系统发牌机制(aapoker真的有猫腻)竟然真的有挂(有挂软件透明挂)-哔哩哔哩...
    黑科技存在(wpk最新黑科技)... 黑科技存在(wpk最新黑科技)wpkai辅助(wpK)好像真的有挂(有挂详细)-哔哩哔哩1、构建自己...