构建应用程序时,Yeoman供应商图像路径不正确

nde*_*ker 7 gruntjs yeoman bower

我正在和Yeoman合作开发一个AngularJS应用程序.

该应用程序依赖于与Bower一起安装的jQuery UI.这是我如何包含jQuery UI主题:

<!-- build:css styles/plugins.css -->
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.core.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.accordion.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.autocomplete.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.button.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.datepicker.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.dialog.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.menu.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.progressbar.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.resizable.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.selectable.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.slider.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.spinner.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.tabs.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.tooltip.css" />
<link rel="stylesheet" href="components/jquery.ui/themes/base/jquery.ui.theme.css" />
<!-- endbuild -->
Run Code Online (Sandbox Code Playgroud)

构建应用程序时,一切顺利,没有错误.

但是,在浏览器控制台(使用Chrome)中,我可以看到jQuery UI Datepicker所需的图像无法找到,因为它看起来在里面styles/images/而且它们实际上在里面components/....

截图

源图片网址

我的第一个想法是覆盖CSS中的jQuery UI图像路径,但这似乎不是最好的解决方案.例:

原始造型

.ui-state-error .ui-icon,
.ui-state-error-text .ui-icon {
    background-image: url(images/ui-icons_cd0a0a_256x240.png)/*{iconsError}*/;
}
Run Code Online (Sandbox Code Playgroud)

我的覆盖

.ui-widget-header .ui-state-error {
    background-image: url(../components/jquery.ui/themes/base/images/ui-bg_glass_95_fef1ec_1x400.png);
}
Run Code Online (Sandbox Code Playgroud)

有推荐的解决方案

Jac*_*cob 7

我有同样的问题.但是,我只是在grunt脚本(Gruntfile.js)中调整了"imagemin"任务,以便将图像复制到预期的位置,而不是更改jQuery CSS(可能对将来的更新有害......).只要grunt负责修改缩小的css中的图像pathes,任何第三方库都是如此.

这是我所做的更改(请注意我的jQuery UI主题文件夹位于该app\styles文件夹下)

之前:

imagemin : {
    dist : {
        files : [{
                expand : true,
                cwd : '<%= yeoman.app %>/images',
                src : '{,*/}*.{png,jpg,jpeg}',
                dest : '<%= yeoman.dist %>/images'
            }
        ]
    }
}
Run Code Online (Sandbox Code Playgroud)

之后:

imagemin : {
    dist : {
        files : [{
                expand : true,
                cwd : '<%= yeoman.app %>/images',
                src : '{,*/}*.{png,jpg,jpeg}',
                dest : '<%= yeoman.dist %>/images'
            }, {
                expand : true,
                flatten : true,
                cwd : '<%= yeoman.app %>/styles',
                src : '**/*.{png,jpg,jpeg,gif}',
                dest : '<%= yeoman.dist %>/styles/images'
            }
        ]
    }
}
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助 !