uniapp(微信小程序)>关于父子组件的样式传递问题(自定义组件样式穿透)

在父组件中给子组件添加类名,子组件的样式由父组件决定

由于"微信小程序"存在【样式隔离机制】,且默认设置为isolated(启用样式隔离),因此这里给出以下两种解决方案:

复制代码
// 小程序编译机制
1. 当 <style scoped> 存在时,uni-app 会通过 ‌添加属性选择器‌ 实现样式隔离(如 [data-v-hash])。
但小程序编译后,自定义组件无法添加此类属性,也就无法命中元素

2. 非 scoped 的 <style> 标签不会添加隔离属性

// H5无论是否添加"scoped"属性,样式表现都一致
H5 的渲染基于浏览器,page 会被解析为 <div> 或 <body> 元素。即使使用 <style scoped>,
由于浏览器默认的样式继承机制, 样式可能间接生效(如通过父元素继承)

1.CSS变量穿透(推荐: 此方案不受样式隔离限制,适配所有端)

缺点:所需的CSS属性要逐个设置变量,自定义组件逐个接收
html 复制代码
 <!-- 父组件 Parent.vue -->
<template>
  <Child class="parent-style"></Child>
</template>

<style>
.parent-style {
  /* 定义 CSS 变量 */
    --img-width: 262rpx;
    --img-height: 120rpx;
    --img-border-radius: 16rpx 16rpx 0 0;
}
</style>  
html 复制代码
<!-- 子组件 Child.vue -->
<template>
  <view class="child-box">
    <image class="child-img" />
  </view>
</template> 

<style>
.child-img {
  width: var(--img-width);
  height: var(--img-height);
  border-radius: var(--img-border-radius);
}
</style>

2.配置隔离模式(不太推荐)

styleIsolation是‌"微信小程序‌"特有的样式隔离配置项,具体有哪些属性值在最下方图中。

在测试中,可能是--组件层级--的缘故,只有配置了"shared"、"page-shared"样式才生效。

注意: 父子组件<style>标签不能添加"scoped"属性,可把这个样式单独放进 <style>

缺点:

1.易造成样式污染,即父子组件若存在同类名会相互干扰样式,其他设置了"shared"的组件可能也会受到污染

2.子组件元素要定位明确,否则无法命中元素

2.1 选项式api:
js 复制代码
 <!-- 父组件 Parent.vue -->
export default {
    options:{
      styleIsolation: 'shared',
    },
    data() {
      return {
      }
    }
}
2.2 组合式api:
js 复制代码
 <!-- 父组件 Parent.vue -->
<script setup>
import { defineOptions } from 'vue';
defineOptions({
  options: {
    styleIsolation: 'shared' 
  }
});
</script>
css 复制代码
<!-- 父组件 Parent.vue(.child-img对应的是子组件中要修改的元素类名) -->
.child-img {
    width: 298rpx;
    height: 186rpx;
    border-radius: 16rpx;
 }


文档地址

相关推荐
计算机程序设计小李同学5 小时前
婚纱摄影集成管理系统小程序
java·vue.js·spring boot·后端·微信小程序·小程序
Mr -老鬼9 小时前
移动端跨平台适配技术框架:从发展到展望
android·ios·小程序·uni-app
一颗小青松11 小时前
uniapp app端显示天气详情
uni-app
计算机徐师兄11 小时前
Java基于微信小程序的食堂线上预约点餐系统【附源码、文档说明】
java·微信小程序·食堂线上预约点餐系统小程序·食堂线上预约点餐微信小程序·java食堂线上预约点餐小程序·食堂线上预约点餐小程序·食堂线上预约点餐系统微信小程序
Swift社区1 天前
H5 与 ArkTS 通信的完整设计模型
uni-app·harmonyos
小溪彼岸1 天前
uni-app小白从0开发一款鸿蒙Next应用到上线
uni-app·harmonyos
毕设源码-邱学长1 天前
【开题答辩全过程】以 基于微信小程序的松辽律所咨询系统的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
一颗小青松1 天前
uniapp app端使用uniCloud的unipush
uni-app
计算机毕设指导61 天前
基于微信小程序的钓鱼论坛系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
qq_12498707531 天前
基于微信小程序的宠物交易平台的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计