假设咱们有一个公共的scss变量文件variables.scsscss
/*存放全部全局变量*/ $card-title:#C7D200; //首页 卡片标题颜色 $bc-color:#182037; $hoverColor: #7abef9; //连接hover颜色 $fontColor: #E6EFFF; //字体颜色-白色
webpack要识别scss,须要先安装sass的loadervue
npm install --save-dev sass-loader //sass-loader依赖于node-sass npm install --save-dev node-sass
在页面中须要用到这些自定义变量的时候,每次都须要显示引入:node
@import '@/assets/scss/variables.scss';
这样操做起来很是麻烦,咱们能够经过sass-resources-loader来自动引入。webpack
sass-resources-loader能够访问sass资源任何一个须要访问的sass模块。因此,能够使用共享变量和混合全部SASS样式,而不去每一个文件都引用。安装:web
npm install --save-dev sass-resources-loader
而后在 build 文件夹下找到 util.js 修改sass编译器loader的配置,直接把下面的代码复制进去便可:vue-router
// 全局文件引入 固然只想编译一个文件的话能够省去这个函数 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-cli
D:\WorkSpace\ui-admin\node_modules\sockjs-client\dist\sockjs.js,找到代码1601行,注释掉代码self.xhr.send(payload);npm
try { //self.xhr.send(payload); } catch (e) {
这样就能够了数组
在引入vue-router的界面中添加以下代码:
sass
const originalPush = Router.prototype.push; Router.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err); };
完!