uni-app在微信小程序端自定义组件中样式穿透失效

news/2024/10/1 3:34:36

前情

uni-app是我比较喜欢的跨平台框架,它能开发小程序/H5/APP(安卓/iOS),重要的是对前端开发友好,自带的IDE让开发体验非常棒,公司项目就是主推uni-app。

坑位

最近因UI有别的事忙,导致手上暂时没什么活了,我于是抽时间优化项目代码,第一件事就是抽取复用组件。正好项目中有多处用到uView的上传组件,上传要处理的逻辑不少,值得封装一下多处复用,在抽组件的过程中我想修改uView的上传组件的样式,对于这种跨组件的样式修改的,当然是用样式穿透了,但另人崩溃的是怎么都不起作用。

Why?

一开始以为是我样式穿透的方式不对,查了文挡,对于uniapp的样式穿有如下几条规则:

  • 如果你使用的是css,没有使用css预处理器,则可以使用>>>,/deep/,::v-deep。
  • 如果你使用的是less或者node-sass,那么可以使用/deep/,::v-deep都可以生效。
  • 如果你使用的是dart-sass,那么就不能使用/deep/,而是使用::v-deep才会生效。

我项目中使用的scss,而且用的是node-scss,我选用是::v-deep,按理说应该是正常的,而且我全局搜了下,我在没有抽组件的另一个页面是成功样式穿透成功的,就排除了是样式穿透的方式不对问题。

经过多翻了解后,是因为我当前开发的是微信小程序端,uniapp最终会把代码转换成微信的wxml/wxss文件跑在微信端,而微信小程序有一个限制,自定义组件的样式只受到自定义组件wxss的影响。

解决方案

在想做样式穿透的组件里增加一个options配置,解除子组件中样式隔离,这样就能样式穿透了。

官方介绍文挡:自定义组件 / 组件模板和样式 (qq.com)

示例代码:

<template><view class="upload-item"><u-upload:fileList="fileList"@afterRead="afterRead"@delete="deletePic"uploadIcon="plus"multiple:maxCount="maxCount"width="128rpx"height="128rpx"/></view>
</template><script>export default {// 解除子组件样式隔离options: {styleIsolation: 'shared'},name:"uploadItem",props: {maxCount: {type: Number,default: 5}},data() {return {fileList: []};},watch: {fileList(newVal, oldVal){console.log('---- newVal ----: ', newVal);const filterList = newVal.filter((upload) => upload.status === 'success');this.$emit('change', filterList);}},methods: {async afterRead(event) {console.log('---- afterRead ----: ', event);// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this.fileList.lengthlists.map((item) => { this.fileList.push({...item,status: 'uploading',message: '上传中'})})// 上传图片for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)let item = this.fileList[fileListLen]this.fileList.splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++}},/*** 图片上传* @param { string } url*/uploadFilePromise(url) {return new Promise((resolve, reject) => {// let a = uni.uploadFile({// 	url: 'http://192.168.2.21:7001/upload', // 仅为示例,非真实的接口地址// 	filePath: url,// 	name: 'file',// 	formData: {// 		user: 'test'// 	},// 	success: (res) => {// 		setTimeout(() => {// 			resolve(res.data.data)// 		}, 1000)// 	}// });})},deletePic(event) {console.log('---- deletePic ----: ', e);this.fileList.splice(event.index, 1);},}}
</script>
<style lang="scss" scoped>.upload-item{::v-deep{.u-upload__wrap__preview {margin:0 8rpx 8rpx 0!important;}.u-upload__button {margin:0!important;}}}</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hjln.cn/news/45051.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

ASP.NET Core应用程序10:使用表单标签助手

本章描述用于创建 HTML 表单的内置标签助手。这些标签助手确保表单提交到正确的操作或页面处理程序方法,并确保元素准确地表示特定的模型属性。本章解释 ASP.NET Core 提供的创建 HTML 表单的功能。展示如何使用标签助手来选择表单目标和关联的 imput、textarea 和 select 元素…

m基于PSO-GRU粒子群优化长门控循环单元网络的电力负荷数据预测算法matlab仿真

1.算法仿真效果 matlab2022a仿真结果如下:优化前: 优化后: 对比如下:2.算法涉及理论知识概要基于粒子群优化(Particle Swarm Optimization, PSO)和长门控循环单元(Gated Recurrent Unit, GRU)网络的电力负荷预测算法,是一种融合了优化技术和深度学习的先进预测模型。…

如何更改IIS中应用程序的虚拟路径

这边的虚拟路径查出来配置错了。 显示的是新建的时候的别名。修改目前我这边是删除重新加一个。

kali更换apt镜像

kali更换apt镜像 vim /etc/apt/sources.list进来之后按i进入编辑模式,把其他的镜像#注释掉之后,加上新的镜像,然后esc退出编辑,按:输入wq保存并退出! 上面的办法不知道为啥没用 修改 /etc/apt/sources.list 文件,也即修改镜像源,能够加快在下载和更新相关软件数据;否则…

数据结构与算法1 简要复习

1.三种复杂度 Ο,读音:big-oh;表示上界,小于等于。 Ω,读音:big omega、欧米伽;表示下界,大于等于。 Θ,读音:theta、西塔;既是上界也是下界,称为确界,等于。 2.抽象数据类型 3.堆,栈(queue,stack) 4.哈希线性探测 二次探测(重要) 二次哈希5.二叉搜索树(BS…

17岁中专女生爆冷逆袭全球数学竞赛12名

17岁中专女生自学偏微分方程,爆冷逆袭高分入围全球数学竞赛,获得竞赛第12名,兴趣是最好的老师。前言 兴趣是最好的老师。 看看她怎么说

seo如何优化

哈喽,大家好,我是木头左,物联网搬砖工一名,致力于为大家淘出更多好用的AI工具!SEO如何优化 一、了解SEO的基本概念 SEO(Search Engine Optimization),即搜索引擎优化,是指通过一系列技术手段,提高网站在搜索引擎中的自然排名,从而获得更多的免费流量。SEO的核心目标…

AI时代的创新工具:如何利用AI生成独具个性的XMind思维导图?

哈喽,大家好,我是木头左,物联网搬砖工一名,致力于为大家淘出更多好用的AI工具!背景 随着互联网的发展,越来越多的人开始使用Markdown来编写文档。Markdown是一种轻量级的标记语言,它允许人们使用简单的文本格式来编写文档,然后将其转换为HTML、PDF等格式。而思维导图则…