vue项目中常见问题及解决方案
程序员文章站
2023-08-21 11:13:43
webpack项目中自动引入全局scss变量文件 假设我们有一个公共的scss变量文件variables.scss webpack要识别scss,需要先安装sass的loader 在页面中需要用到这些自定义变量的时候,每次都需要显示引入: 这样操作起来非常麻烦,我们可以通过sass-resource ......
webpack项目中自动引入全局scss变量文件
假设我们有一个公共的scss变量文件variables.scss
/*存放所有全局变量*/ $card-title:#c7d200; //首页 卡片标题颜色 $bc-color:#182037; $hovercolor: #7abef9; //链接hover颜色 $fontcolor: #e6efff; //字体颜色-白色
webpack要识别scss,需要先安装sass的loader
npm install --save-dev sass-loader //sass-loader依赖于node-sass npm install --save-dev node-sass
在页面中需要用到这些自定义变量的时候,每次都需要显示引入:
@import '@/assets/scss/variables.scss';
这样操作起来非常麻烦,我们可以通过sass-resources-loader来自动引入。
sass-resources-loader可以访问sass资源任何一个需要访问的sass模块。所以,可以使用共享变量和混合所有sass样式,而不去每个文件都引用。安装:
npm install --save-dev sass-resources-loader
然后在 build 文件夹下找到 util.js 修改sass编译器loader的配置,直接把下面的代码复制进去即可:
// 全局文件引入 当然只想编译一个文件的话可以省去这个函数 function resolveresource(name) { return path.resolve(__dirname, '../src/assets/scss/' + name); } function generatesassresourceloader() { var loaders = [ cssloader, 'sass-loader', { loader: 'sass-resources-loader', options: { // 多个文件时用数组的形式传入,单个文件时可以直接使用 path.resolve(__dirname, '../src/assets/scss/variables.scss' resources: [resolveresource('variables.scss')] //variables } } ]; if (options.extract) { return extracttextplugin.extract({ use: loaders, fallback: 'vue-style-loader' }); } else { return ['vue-style-loader'].concat(loaders); } }
return { css: generateloaders(), postcss: generateloaders(), less: generateloaders('less'), // vue-cli默认sass配置 // sass: generateloaders('sass', { indentedsyntax: true }), // scss: generateloaders('sass'), // 新引入的sass-resources-loader sass: generatesassresourceloader(), scss: generatesassresourceloader(), stylus: generateloaders('stylus'), styl: generateloaders('stylus') };
......
vue-cli3 一直运行 /sockjs-node/info?t= 解决方案
d:\workspace\ui-admin\node_modules\sockjs-client\dist\sockjs.js,找到代码1601行,注释掉代码self.xhr.send(payload);
try { //self.xhr.send(payload); } catch (e) {
这样就可以了
解决vue中的navigationduplicated {_name: "navigationduplicated", name: "navigationduplicated"}
在引入vue-router的界面中添加如下代码:
const originalpush = router.prototype.push; router.prototype.push = function push(location) { return originalpush.call(this, location).catch(err => err); };
完!