vue项目中常见问题及解决方案_白峰_前端开发者

webpack项目中自动引入全局scss变量文件

  假设我们有一个公共的scss变量文件variables.scss

variables.scss

/*存放所有全局变量*/
$card-title:#C7D200; //首页 卡片标题颜色
$bc-color:#182037;
$hoverColor: #7abef9; //链接hover颜色
$fontColor: #E6EFFF; //字体颜色-白色
/*存放所有全局变量*/
$card-title:#C7D200; //首页 卡片标题颜色
$bc-color:#182037;
$hoverColor: #7abef9; //链接hover颜色
$fontColor: #E6EFFF; //字体颜色-白色

/*存放所有全局变量*/
$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
npm install --save-dev sass-loader
//sass-loader依赖于node-sass
npm install --save-dev node-sass

installloader
//sass-loader依赖于node-sassinstall

  在页面中需要用到这些自定义变量的时候,每次都需要显示引入:

  @import '@/assets/scss/variables.scss';
  @import '@/assets/scss/variables.scss';

  @import ‘@/assets/scss/variables.scss’;

  这样操作起来非常麻烦,我们可以通过sass-resources-loader来自动引入。

  sass-resources-loader可以访问sass资源任何一个需要访问的sass模块。所以,可以使用共享变量和混合所有SASS样式,而不去每个文件都引用。安装:

npm install --save-dev sass-resources-loader
npm install --save-dev sass-resources-loader

install

  然后在 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);
        }
    }
 // 全局文件引入 当然只想编译一个文件的话可以省去这个函数
    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);
        }
    }

// 全局文件引入 当然只想编译一个文件的话可以省去这个函数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’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')
    };
    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')
    };

return {
css: generateLoaders(),
postcss: generateLoaders(),
lessless),
// 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);

self.xhr.send(payload);

  try {
    //self.xhr.send(payload);
  } catch (e) {
  try {
    //self.xhr.send(payload);
  } catch (e) {

try {
//self.xhr.send(payload);catch

这样就可以了

解决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);
};
const originalPush = Router.prototype.push;
Router.prototype.push = function push(location) {
  return originalPush.call(this, location).catch(err => err);
};

Router.prototype.push;
Router.prototype.push
function push(location) {
returnthiscatch err);
};

完!

» 本文来自:前端开发者 » 《vue项目中常见问题及解决方案_白峰_前端开发者》
» 本文链接地址:https://www.rokub.com/73796.html
» 您也可以订阅本站:https://www.rokub.com
赞(0)
64K

评论 抢沙发

评论前必须登录!