gpt4 book ai didi

requirejs - 尝试使用 grunt-contrib-requirejs 将所有 JS 压缩到一个文件

转载 作者:行者123 更新时间:2023-12-01 05:15:56 26 4
gpt4 key购买 nike

我有以下目录结构(仅相关位):

app
- build
- script.js
- js
- lib
- require.js
- jquery-1.10.2.js
- app.js
- index.html
Gruntfile.js

Gruntfile.js 包含以下内容:
module.exports = function (grunt) {

var gruntConfig = {
pkg: grunt.file.readJSON('package.json'),
requirejs: {
compile: {
options: {
name: 'app',
baseUrl: 'app/assets/js',
out: 'app/assets/build/script.js',
include: ['lib/require'],

uglify: {
// beautify: true,
defines: {
DEBUG: ['name', 'false']
}
},

paths: {
jquery: "lib/jquery-1.10.2"
}
}
}
},
};

grunt.initConfig(gruntConfig);

grunt.loadNpmTasks('grunt-contrib-requirejs');

};

app.js 包含以下内容:
require(['jquery'], function ($) {
// Do stuff
});

我如何设置它,以便它复制所有需要的 JavaScript 到 build/script.js,而不仅仅是 app.js 和 require.js,当我告诉它时(当我尝试使用 jQuery 时出错)?我还希望能够在不将它们添加到我的 Gruntfile 的情况下添加模块,只需将它们添加到 script.js 即可。

最佳答案

您可以定义一个 mainConfigFile 并在配置文件中包含指向您的 lib 代码的路径,如下所示

gruntfile 的内容:

requirejs: {
compile: {
options: {
baseUrl: "app/js/",
mainConfigFile: app/config.js",
out: "build/script.js",
name: "config"
}
}
}

配置文件内容:
require.config({
paths: {
lib: "<path to>/js/lib",
jquery: "<path to>/js/lib/jquery-1.10.2.min",
.
and particular file required
.
}

Requirejs 会将所有路径文件的内容添加到优化后的代码中。

关于requirejs - 尝试使用 grunt-contrib-requirejs 将所有 JS 压缩到一个文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20617504/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com