首页 > 编程语言 >uni-app在微信小程序端自定义组件中样式穿透失效

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

时间:2024-06-13 19:55:07浏览次数:12  
标签:自定义 样式 微信 app upload deep ---- fileList 组件

前情

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.length
				lists.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>

标签:自定义,样式,微信,app,upload,deep,----,fileList,组件
From: https://www.cnblogs.com/xwwin/p/18246667

相关文章

  • java:【@ComponentScan】和【@SpringBootApplication】扫包范围的冲突
    #代码结构如下:注意【com.chz.myBean.branch】和【com.chz.myBean.main】这两个包是没有生重叠的。主程序【MyBeanTest1、MyBeanTest2、MyBeanTest3】这两个类是在包【com.chz.myBean.main】下#示例代码【pom.xml】<dependency><groupId>org.springframework.bo......
  • 强制app横屏显示或者竖屏显示(动态)
    需求:某个app横屏显示不全,需要强制它竖屏显示,强制APP旋转优先级>系统方向优先级如果系统没有强制横竖屏,一般都是默认应用本身的方向设置!./frameworks/base/services/core/java/com/android/server/wm/DisplayRotation.javarotationForOrientation()和updateOrientation()来负责......
  • Android 11 自由窗口模式启动app
    //未定义publicstaticfinalintWINDOWING_MODE_UNDEFINED=0;//普通全屏窗口publicstaticfinalintWINDOWING_MODE_FULLSCREEN=1;//画中画publicstaticfinalintWINDOWING_MODE_PINNED=2;//分屏主窗口publicstaticfinali......
  • 海外一对一视频聊天APP开发搭建源码方案
    国际版1v1视频交友APP的基础功能和搭建应用程序的考虑方面,以下是进一步的分析和建议:一、基础功能优化建议注册和登录系统:简化流程:减少不必要的步骤,使注册和登录更加快速。第三方登录支持:增加对主流社交平台的登录支持,方便用户快速注册。用户验证:加强手机或邮箱验证,提高用户......
  • 语音厅语音房APP开发砸蛋社交源码软件搭建开发
    开发语音厅语音房软件确实是一项复杂且专业的任务,需要综合考虑市场需求、功能需求、技术选型、界面设计、开发工作、测试优化以及上线维护等多个方面。以下是针对您提供的内容的详细展开:一、市场需求分析进行语音厅语音房软件的开发前,首先需要对市场进行深入的调研,了解当前......
  • 情趣商城成人用品小程序APP开发源码搭建
    搭建成人情趣用品商城APP小程序是一个需要综合考虑多方面因素的复杂过程。下面,我将详细为您分析搭建过程中需要特别注意的几个关键点,并给出一些建议,以帮助您更好地规划和实施这个项目。一、市场定位与用户需求首先,您需要明确您的市场定位和目标用户群体。情趣用品市场有其特......
  • App UI 风格展现非凡创意
    AppUI风格展现非凡创意......
  • x.thumbnailer 修复psd缩略图/nemo-preview 自定义预览
    缩略图https://askubuntu.com/questions/1368910/how-to-create-custom-thumbnailers-for-nautilus-nemo-and-caja安装imagemagicksudoaptinstallimagemagick-6.q16/usr/share/thumbnailers/psd.thumbnailerhttps://moritzmolch.com/blog/1749.htmlcd/usr/share/thumbn......
  • 基于云效 AppStack,5 分钟搞定一个 AI 应用的开发和部署
    实验介绍区别于传统的流水线工具,本实验将带你体验云效应用交付平台AppStack,从应用视角,完成一个AI聊天应用的高效交付。你将体验到:基于应用模板快速初始化应用,包含应用的代码库、部署编排架构、变量组、环境、研发流程等;应用多环境管理、多种部署策略、部署可观测能力;通过......
  • 基于云效 AppStack,5 分钟搞定一个 AI 应用的开发和部署
    实验介绍区别于传统的流水线工具,本实验将带你体验云效应用交付平台AppStack,从应用视角,完成一个AI聊天应用的高效交付。你将体验到:基于应用模板快速初始化应用,包含应用的代码库、部署编排架构、变量组、环境、研发流程等;应用多环境管理、多种部署策略、部署可观测能力;通过......