本文介绍: 由于UI组件内部样式我们不是完全清楚,所以,以上方法,都可以尝试,那种方式可以,就用那种。其实,你可以打开chrome浏览器元素elements),查看不同组件内部标签结构样式,先做做尝试,再在代码中写,同时,也能够了解UI组件库内部的样式情况。

一、场景

       一般来说,我们使用第三方UI组件库(如:vantelementplus等)时,UI组件自带样式不能满足用户的个性化需求时,就需要我们开发人员自己动手对组件库的局部样式进行修改

二、修改UI组件库的顺序方法

1、修改主题

1、修改主题每个ui组件库都有专门的修改主题解释,如vantVant 3 – Lightweight Mobile UI Components built on Vue

2、使用props

如:elementpluselbuton组件,可以通过 修改type属性取值,来改变外观样式

<el-button type="primary">按钮</el-button>

3、添加 class/style
&lt;el-button type="success" class="mybutton" style="height: 250px;"&gt;按钮</el-button&gt;
​
​
<style lang="css" scoped&gt;
​
.mybutton{
    border-radius: 20px;
}
    
</style&gt;

如果某个属性覆盖不了,就加属性权重

.mybutton{ borderradius: 20px !important; }

4、查看元素查询相关样式名,修改编译后的样式
<el-button type="success" class="mybutton" style="height: 250px;"&gt;按钮</el-button&gt;
​
<style lang="css" scoped&gt;
​
.mybutton{
    border-radius: 20px;
}
​
.el-button{
    width: 600px;
}
    
</style>

5、样式穿透覆盖ui组件库的样式名)
1)、 .a >>> .b { /* … */ } 深度选择器

果实在不行的话,可以考虑给外面加一个容器

即: 自定义的样式名 >>> ui组件库的样式名

注意:这个写法sassless支持

<template>
    <el-table class="mytable" :data="tableData" style="width: 100%">
      <el-table-column prop="date" label="Date" width="180" />
      <el-table-column prop="name" label="Name" width="180" />
      <el-table-column prop="address" label="Address" />
    </el-table>
  </template>
  
  <script  setup>
  const tableData = [
    {
      date: '2016-05-03',
      name: 'Tom',
      address: 'No. 189, Grove St, Los Angeles',
    },
    {
      date: '2016-05-02',
      name: 'Tom',
      address: 'No. 189, Grove St, Los Angeles',
    }
  ]
  </script>
​
<style scoped>
​
.mytable >>> .el-table_1_column_1  .cell{
    background-color: red;
}
​
</style>

2)、 /deep/ ui组件选择器 { }
/deep/ .a{
​
    ***
​
}

sassless写法:

<style lang="scss" scoped>
.a{
  /deep/ .b { 
  /* ... */
 }
}
</style>

scoped 影响 (不加scoped,deep不生效

3)、::vdeep ui组件选择器 { }
::v-deep .a{
​
    ***
​
}

示例代码

<el-button type="success" class="mybutton" style="height: 250px;">按钮</el-button>
​
<style lang="css" scoped>
​
.mybutton{
    border-radius: 20px;
}
​
::v-deep .el-button span{
    width: 100px;
    height: 30px;
    background-color: aqua;
}
​
.el-button{
    width: 600px;
}
​
</style>


sassless写法:

<style lang="scss" scoped>
.a{
 ::v-deep .b { 
  /* ... */
 }
} 
</style>

/deep/在某些时候报错,::v-deep更保险并且编译速度更快.

三、最后

由于UI组件库内部的样式我们不是完全清楚,所以,以上方法,都可以尝试,那种方式可以,就用那种。

其实,你可以打开chrome浏览器的元素(elements),查看不同组件的内部标签结构和样式,先做做尝试,再在代码中写,同时,也能够了解UI组件库内部的样式情况。

原文地址:https://blog.csdn.net/jiang7701037/article/details/134699757

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_43316.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注