跨平台应用开发进阶(二十) :uni-data-checkbox组件实现自定义样式及注意事项

一、前言

uni-app项目开发过程中,需要实现单选同意用户协议效果,但是交互方式采用多选,即点击-选中,点击-取消效果。 更改的时候需要注意以下几点:

  1. 因为uni-app默认组件是定义好了的,如果要修改可以找到组件所属css,也可以自行修改样式并覆盖原有样式。

  2. 选择自行修改的时候,一定在app.vue页面去引入更改的css或者直接在此页面进行修改,否则修改无效。

  3. 不要在style中增加scoped属性。

  4. 注意小程序中跟h5页面是略有不同的,如下官方语句

关于第3点," 不要在style中增加scoped属性 "尤为不解,本页面的样式控制本页面渲染视图样式,却不能使用scoped,存在污染其他页面样式的风险。

二、码上谈兵

CSS部分的实现如下:

css 复制代码
<style>
	.agreeTxt-left label {
		padding-right: 0;
		margin-right: 0 !important;
	}
	.agreeTxt-left.uni-data-checklist {
		flex: 0 1 auto;
	}
	.uni-data-checklist .checklist-group .checklist-box .checklist-content .checklist-text {
		font-size: 24rpx !important;
		color: #999 !important;
		margin-left: 10rpx !important;
		line-height: 24rpx !important;
	}
	
	.uni-data-checklist .checklist-group .checklist-box .checkbox__inner {
		border-radius: 7.5px !important;
		width: 15px !important;
		height: 15px !important;
	}
</style>

上面说到关于注意到的第3点," 不要在style中增加scoped属性 "存在污染其他页面样式的风险,所以在控制CSS样式的时候,根据样式作用范围,只将需要用到的样式控制为全局样式,其余样式做scoped处理,最大化减少样式污染的风险。

三、拓展阅读

相关推荐
LinDaiDai_霖呆呆16 小时前
我用 Claude Code 一天搭了个高扩展性的 Web 3D 编辑器 SDK,但最有价值的不是代码 🔥
前端·ai编程·claude
AZaLEan__16 小时前
Flex 弹性布局学习总结
前端·css·css3
成都渲染101云渲染666617 小时前
云渲染全面支持3dsMax 2027,高效渲染体验升级
开发语言·前端·javascript
卸任17 小时前
别用Quill了,打造自己的Tiptap富文本编辑器
前端·react.js
陈广亮17 小时前
React 图表库选型指南:Recharts、ECharts、Nivo、Lightweight Charts 深度对比
前端
zs宝来了17 小时前
微前端架构:qiankun 沙箱隔离与样式冲突
前端·javascript·框架
M ? A17 小时前
Vue 的 scoped 样式穿透 React 不支持?用 VuReact 编译就行
前端·javascript·vue.js·react.js·面试·开源·vureact
zs宝来了17 小时前
Vue 3 Composition API:响应式系统与依赖追踪
前端·javascript·框架
李伟_Li慢慢17 小时前
wolfram详解山峦算法
前端·算法
村上小树17 小时前
非常简单地学习一下slate.js的原理
前端·javascript