javascript - vue单文件style里scoped无效,求指教原因。
仅有的幸福
仅有的幸福 2017-05-19 10:27:37
[JavaScript讨论组]

a.vue

<template>
    <p>
        <button class="btn btn-primary">11a.vue</button>
    </p>
</template>
<style scoped>
    @import '../css/bootstrap.css';
    
</style>

b.vue

<template>
    <p>
        <button class="btn btn-primary">b.vue</button>
    </p>
</template>
<style scoped>
    
</style>

但是在访问b.vue的时候却附带了boostrap的样式,scoped没起隔离作用域的效果?

仅有的幸福
仅有的幸福

全部回复(3)
phpcn_u1582

我猜测啊,是@import的原因

首先我们看一下vue-loader的scoped的原理:
https://vue-loader.vuejs.org/...

b页面带有bootstrap的样式只能说明bootstrap的css没有经过vue-loader处理,然后我又去搜了以下postcss和@import关键字,然后发现了postcss-import插件:
https://www.npmjs.com/package...

我觉得你把这个插件用上的话应该可以解决问题,但我没测试,纯属猜测

过去多啦不再A梦

你找下b的父级页面,一级一级往上找,肯定是那个页面引用了

大家讲道理

@import '../css/bootstrap.css';去掉;
换成<style src="../css/bootstrap.css" scoped></style>就好了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号