uniapp web 灵活控制 style scoped

前言

郑重承诺以下内容不由 AI 生成

最近在一个 uni-app vue3 的项目,运行到 web 的时候发现,页面中不添加 scoped 样式,仍然是开启了 scoped 的效果,导致样式无法全局生效,经过一番查找,发现是 uni-app 默认所有页面都开启了 scoped,本文记录如何解除这个限制。

测试代码

html 复制代码
<template>
  <view class="page">
    <view class="hero">
      <text class="eyebrow">Main package</text>
      <text class="title">Rattail array helpers</text>
      <text class="desc">
        This page lives in the main package and imports functions from rattail.
      </text>
    </view>

    <view class="card">
      <text class="label">source</text>
      <text class="code">{{ sourceText }}</text>
    </view>

    <button class="button" @click="goSubPackage">
      Open sub package rattail demo
    </button>
  </view>
</template>

<script setup>
import { computed } from 'vue'
import { isString } from 'rattail'

const numbers = [1, 2, 2, 3, 4, 4, 5, 6]

const sourceText = computed(() => isString(numbers) ? 'A string' : 'Not a string')

function goSubPackage() {
  uni.navigateTo({
    url: '/pages/sub/rattail/index',
  })
}
</script>

// 这里并没有添加 scoped
<style>
.page {
  min-height: 100vh;
  padding: 40rpx 32rpx;
  background: linear-gradient(135deg, #fff7e6 0%, #e9f7ef 48%, #e8f1ff 100%);
  box-sizing: border-box;
}

.hero {
  display: flex;
  flex-direction: column;
  gap: 14rpx;
  margin-bottom: 28rpx;
}

.eyebrow {
  color: #2f6f55;
  font-size: 24rpx;
  font-weight: 700;
  letter-spacing: 4rpx;
  text-transform: uppercase;
}

.title {
  color: #16231e;
  font-size: 44rpx;
  font-weight: 800;
}

.desc {
  color: #52615b;
  font-size: 28rpx;
  line-height: 1.6;
}

.card {
  padding: 28rpx;
  margin-bottom: 22rpx;
  border: 2rpx solid rgba(22, 35, 30, 0.08);
  border-radius: 28rpx;
  background: rgba(255, 255, 255, 0.75);
  box-shadow: 0 18rpx 40rpx rgba(47, 111, 85, 0.1);
}

.label {
  display: block;
  margin-bottom: 14rpx;
  color: #2f6f55;
  font-size: 24rpx;
  font-weight: 700;
}

.code {
  color: #16231e;
  font-family: Menlo, Consolas, monospace;
  font-size: 24rpx;
  line-height: 1.6;
  white-space: pre-wrap;
}

.button {
  margin-top: 18rpx;
  color: #ffffff;
  background: #1f7a5a;
  border-radius: 999rpx;
  font-weight: 700;
}
</style>

解决方案

如果是 cli 项目,找到 node_modules/@dcloudio/uni-h5-vite/dist/index.js 文件,注释 uniCssScopedPlugin

如果是 hbuilderx 项目,找到 /Applications/HBuilderX.app/Contents/HBuilderX/plugins/uniapp-cli-vite/node_modules/@dcloudio/uni-h5-vite/dist/index.js 文件

运行效果

写在最后

感觉您耐心看完这篇文章,希望您能喜欢。这里是《前端毕业班》,前端开发者的自救互助小组。在 AI 与不确定性并存的时代,我们一起看清焦虑,聊技术、聊趋势,也聊前端还能走多远,走去哪。

相关推荐
旧曲重听12 小时前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
Kapaseker2 小时前
我找到了最适合程序员的 PPT 工具 — Slidev
前端
夏幻灵2 小时前
深度解析 JavaScript 异步编程:从回调地狱到 Promise 的重构
开发语言·javascript·重构
雾削木2 小时前
B语言经典教程现代化重构
java·前端·stm32·单片机·嵌入式硬件
Cobyte2 小时前
20.Vue Vapor 的应用初始化
前端·javascript·vue.js
乘风gg2 小时前
手把手带你实践历时一年总结的 AI Code Review 最佳工作流!
前端·ai编程·cursor
禅思院2 小时前
POST请求发两次?一次讲透CORS预检机制,面试不再翻车
前端·架构·前端框架
IT_陈寒2 小时前
SpringBoot自动配置这么智能,为啥我写的Bean注入不了?
前端·人工智能·后端
LT10157974442 小时前
2026年Web自动化测试工具选型指南:多浏览器兼容解决方案
前端·测试工具·自动化
vx-Biye_Design2 小时前
springboot安阳地区研学旅游服务小程序-计算机毕业设计源码12785
java·vue.js·windows·spring boot·tomcat·maven·mybatis