uniapp /deep/设置子组件样式 h5生效,小程序失效问题解决 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

uniapp /deep/设置子组件样式 h5生效,小程序失效问题解决

发表时间:2020-10-19

发布人:葵宇科技

浏览次数:357

uniapp /deep/设置子组件样式 h5生效,小程序失效问题解决

本项目是用typescript搭建的uniapp项目,使用vue-property-decorator装饰器
在父组件内设置子组件的样式 代码如下

<style lang="scss" scoped>
.device-panel {
    /deep/ .cc-icon {
        font-size: 70rpx !important;
    }
}

但是只在H5生效,在小程序失效,解决办法如下
微信文档https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/wxml-wxss.html#%E7%BB%84%E4%BB%B6%E6%A0%B7%E5%BC%8F%E9%9A%94%E7%A6%BB
中提到需要设置styleIsolation属性为shared,才能影响到子组件的样式
在代码中增加options选项,增加styleIsolation属性,设置为shared

@Component({
    components: {
        CcSwitch,
        CcIcon,
    },
    options: { styleIsolation: 'shared' },
})

但是这样typescript编译报错
and ‘options’ does not exist in type 'ComponentOptions<Vue, DefaultData, DefaultMethods, DefaultComputed, PropsDefinition<Record<string, any>>, Record<…>> & ThisType<…>
原因是options这个选项ComponentOptions里面没有,目前暂时没找到方法解决,后续找到方法会继续跟进的

如果很在意这个报错建议用Vue.extends的写法

相关案例查看更多