jquery - 如何使用 webpack 添加 jquery-ui css/图像

标签 jquery jquery-ui webpack

我将 jquery-ui 与 webpack 一起使用,但在如何从 node_modules 文件夹加载捆绑的 css 和图像方面遇到问题。

我有自己的 scss 文件,但还需要加载 jquery-ui css。为了完成此任务,我添加了以下 webpack 配置规则。

{
    test: /\.scss$/,
    include: [
        path.resolve(__dirname, "client/css/scss"),
    ],
    use: [{
        loader: "style-loader" // creates style nodes from JS strings
    }, {
        loader: "css-loader" // translates CSS into CommonJS
    }, {
        loader: "sass-loader" // compiles Sass to CSS
    }]
},
{
    test: /all\.css$/,
    include: [
        path.resolve(__dirname, "node_modules/jquery-ui/themes/base"),
    ],
    use: [{
        loader: "style-loader" // creates style nodes from JS strings
    }, {
        loader: "css-loader" // translates CSS into CommonJS
    }]
}

注意版本:

"jquery": "3.2.1",
"jquery-ui": "1.12.1",

在我的 js 入口文件中下一步:

require("../css/scss/main.scss");
require("../../node_modules/jquery-ui/themes/base/all.css");

但是在构建时这给出了:

ERROR in ./node_modules/jquery-ui/themes/base/images/ui-icons_777620_256x240.png Module parse failed: /home/anders/Code/imjustworking/node_modules/jquery-ui/themes/base/images/ui-icons_777620_256x240.png Unexpected character '�' (1:0)

所以我想我需要一些额外的 png 加载器: { 测试:/.png$/, 包括: [ path.resolve(__dirname, "node_modules/jquery-ui/themes/base/images"), ], 使用: { 加载器:“url-loader?limit=100000” } } 但后来我遇到了这个我不想改变的政策:

Refused to load the image '…MDrH4y9V+CDsjWf1nOApn6L+F1gNV/F48BB4BR+zUwcIfzP/8S/ZOlvFfuAAAAAElFTkSuQmCC' because it violates the following Content Security Policy directive: "img-src 'self'".

这就是我现在所在的地方。我确实找到了一些其他关于如何执行此操作的示例,但它们大多来自早期对 webpack 不太友好的 jquery-ui 版本。任何建议表示赞赏。我怀疑有比我上面的尝试更好的方法吗?

最佳答案

上官方jquery-ui's page解释他们链接到 a github repository providing a minimal working example 的 npm 的用法如何使用 webpack 设置 jquery-ui。 我让它工作的方式(稍微调整存储库的指令)是 如下:

  1. 安装了文件加载器模块(npm i -S file-loader)
  2. 添加了以下规则:

    {
        test: /\.(jpg|png)$/,
        loader: 'file-loader'
    },
    

所以基本上我处理 css、scss 和 jquery ui 所需的样式表的方式是(webpack.config.js):

module: {
    rules: [
    {
        test: /\.s*css$/,
        use: [
            "style-loader", // creates style nodes from JS strings
            "css-loader", // translates CSS into CommonJS
            "sass-loader" // compiles Sass to CSS, using Node Sass by default
        ]
    },
    {
        test: /\.(jpg|png)$/,
        loader: 'file-loader'
    },
    ]
},

在我的应用程序的 js 文件中:

require("jquery-ui/ui/widgets/autocomplete");
require("jquery-ui/ui/widgets/draggable");
require("jquery-ui/ui/widgets/selectmenu");
require("jquery-ui/ui/widgets/slider");
require('jquery-ui/themes/base/all.css');

关于jquery - 如何使用 webpack 添加 jquery-ui css/图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45300516/

相关文章:

javascript - Metro Live Tile Like Twitter Feed with MetroJS

javascript - 检查各个 div 的文本并更改内容

jquery - 当内容展开时,在 jQuery 动画期间展开 iframe

jquery - 通过类获取 jqueryui 背景按钮颜色

javascript - Webpack 构建错误

javascript - Firefox 不响应 .addClass

javascript - Underscore.js - 检查对象数组是否包含值

javascript - 检查下一个元素是否是特定元素

javascript - Webpack 没有在生产环境中最小化我的 JavaScript 文件

javascript - Node.js 需要 webpack 模块