el-dialog自定义弹窗做ElMessageBox.comfirm三个按钮类型

html: 

<el-dialog v-if="orderRefundInfo" v-model="dialogShow" width="360px" title="" :close-on-press-escape="false">
  <template #header>
    <div class="refund-header">
      <el-icon color="#f2a813" :size="25">
        <WarningFilled />
      </el-icon>
      <div class="refund-header-title">确认退款</div>
    </div>
  </template>
  <div>
    <div>
      {{
        `套餐${orderRefundInfo?.package_days}天,实付${orderRefundInfo?.order_amount}元,实际使用${orderRefundInfo?.used_days}天${orderRefundInfo?.used_hours}小时。部分退款:`
      }}
    </div>
    <div class="tip">
      {{
        `(${orderRefundInfo?.rest_days}天 / ${orderRefundInfo?.package_days}天) * ${orderRefundInfo?.order_amount}元 = ${orderRefundInfo?.refund_amount}元`
      }}
    </div>
  </div>
  <template #footer>
    <el-button @click="dialogShow = false">取消</el-button>
    <el-button type="primary" :disabled="orderRefundInfo?.package_days == orderRefundInfo?.rest_days" @click="orderRefund(orderRefundInfo?.refund_amount)"
      >部分退</el-button
    >
    <el-button type="danger" @click="orderRefund(orderRefundInfo?.order_amount)">全额退</el-button>
  </template>
</el-dialog>

css: 

.tip {
  color: #e57c89;
}

.refund-header {
  display: flex;
  align-items: center;

  .refund-header-title {
    margin-left: 15px;
    color: #575757;
    font-size: 14px;
    font-weight: 600;
  }
}

<think>我们正在处理一个关于修改Element UI中el-dialog弹窗圆角样式的问题。根据提供的引用,我们可以总结出两种方法: 1. 在全局样式(如App.vue)中覆盖el-dialog的样式,并加上!important。 2. 封装自定义弹框组件,通过局部样式覆盖。 用户的问题是如何修改el-dialog弹窗的圆角。我们将提供两种方法,并解释注意事项。 方法一:全局样式覆盖 在App.vue或全局样式文件中,添加以下样式: ```css .el-dialog { border-radius: var(--el-border-radius-small) !important; } ``` 注意:这里使用了!important来提升样式优先级,确保覆盖原有样式。 方法二:局部样式覆盖(使用深度选择器) 如果不想影响全局,可以在使用el-dialog的组件内使用深度选择器(::v-deep或/deep/)来覆盖样式。在Vue3中,推荐使用:deep()。 例如,在组件的style标签中(scoped情况下): ```css :deep(.el-dialog) { border-radius: 10px !important; /* 使用自定义的圆角值 */ } ``` 注意:在Vue3中,使用scoped时,为了覆盖子组件的样式,需要使用深度选择器。 另外,引用[1]中提到在全局样式中定义变量并覆盖,但这里我们直接设置圆角值也可以。 根据用户需求,我们给出具体步骤和代码示例。 步骤: 1. 确定修改范围(全局还是局部)。 2. 在对应的样式文件中添加覆盖样式,并加上!important。 3. 如果需要使用主题变量,可以使用Element UI提供的CSS变量(如--el-border-radius-small),也可以直接使用像素值。 示例代码(全局修改,在App.vue的style标签中): ```html <style lang="scss"> .el-dialog { border-radius: 8px !important; } </style> ``` 或者局部修改(在具体组件的style标签中): ```html <style scoped lang="scss"> :deep(.el-dialog) { border-radius: 8px !important; } </style> ``` 注意事项: - 如果全局修改,会影响所有的el-dialog- 局部修改只影响当前组件内的el-dialog- 使用!important是为了确保覆盖,因为Element UI的样式优先级可能较高。 如果用户使用的是Sass或Less,语法类似。 根据引用[2],自定义弹框组件也是一种方式,但如果只是修改圆角,直接覆盖样式更简单。 因此,我们推荐使用样式覆盖的方法。 下面生成相关问题:</think>要修改 Element UI 中 `el-dialog` 弹窗的圆角样式,可以通过以下两种方法实现: ### 方法一:全局样式覆盖(推荐) 在项目的全局样式文件(如 `App.vue` 或 `global.scss`)中添加以下代码: ```scss /* 覆盖 el-dialog 圆角 */ .el-dialog { border-radius: 12px !important; /* 自定义圆角值 */ } ``` **关键点说明**: 1. 必须使用 `!important` 提升样式优先级 2. 文件位置: - 在 `App.vue` 的 `<style>` 标签中直接添加 - 或在全局 SCSS 文件中导入(需确保在入口文件引入) 3. 自定义圆角值建议使用 CSS 变量(如 `var(--el-border-radius-base)`)保持设计一致性 ### 方法二:局部组件覆盖(Scoped 样式) 在具体组件中使用深度选择器: ```vue <style scoped lang="scss"> /* 深度穿透选择器 */ :deep(.el-dialog) { border-radius: 8px !important; } </style> ``` ### 注意事项 1. **优先级问题**:Element UI 的默认样式优先级较高,必须使用 `!important` 才能覆盖 2. **响应式适配**:圆角值建议使用相对单位(如 `rem`)或 CSS 变量 3. **主题一致性**:若使用自定义主题,建议通过 `:root` 定义圆角变量: ```scss :root { --dialog-radius: 10px; } .el-dialog { border-radius: var(--dialog-radius) !important; } ``` > 引用说明:全局样式覆盖需要 `!important` 的解决方案参考自 Vue 社区实践[^1],深度选择器语法符合 Vue 3 样式穿透规范[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值