1

我有一个 Django 应用程序,在该应用程序中我试图捆绑和缩小所有 Javascript 文件和 CSS 文件。

为此,我使用 django-pipeline 1.2.6,并且我已经配置了我的设置文件,以便它使用默认的 YUICompressor 来压缩 JS 和 CSS 文件。我的设置文件配置如下:

...

# PIPELINE SETTINGS (for compressing/bundling css and js files)
STATICFILES_STORAGE = "pipeline.storage.PipelineCachedStorage"

PIPELINE_YUI_BINARY = "/usr/bin/yui-compressor"

PIPELINE_JS = {
    'min': {
        'source_filenames': (              
            "js/*.js",
        ),
        'output_filename': 'js/min.js'
    }
}

PIPELINE_CSS = {
    ...
}

PIPELINE = True

当我运行命令python src/foo_app/manage.py collectstatic时,我得到了“破管”异常。我很快意识到 yui-compressor 由于 JS 的问题而崩溃。所以我开始隔离导致 yui-compressor 崩溃的文件和代码行。

我最终将其缩小到两行,为 jquery 弹出窗口上的按钮定义类属性:

    $('#some-modal').dialog({
        ...
        buttons: [
            {
                text  : 'Print',
                click : function() {
                    ...
                },
                class : 'foo-class bar-class' // <- this line
            },
            {
                text  : 'Close',
                click : function() {
                    ...
                },
                class : 'foo-class bar-class' // <- this line
            }
        ],
    });

当我删除这些类定义时,yui-compressor 可以很好地压缩我的 JS。但是,如果包含这些行,yui-compressor 会崩溃。

为什么这些线路会导致压缩机崩溃?这是有效的 Javascript,并且确实正确设置了这些按钮的类别。

4

1 回答 1

1

也许这与 yui-compressor ES6 类关键字处理有关。尝试将class密钥用引号括起来:

改变这个:

class : 'foo-class bar-class' // <- this line

至:

'class' : 'foo-class bar-class' // <- this line
于 2016-07-14T18:03:16.093 回答