gpt4 book ai didi

javascript - 使所需的依赖项可以从包外部访问

转载 作者:行者123 更新时间:2023-12-03 05:27:24 24 4
gpt4 key购买 nike

我正在使用 Gulp 和 Browserify 构建一个 TypeScript 库,该库依赖于其他一些库,例如通过 NPM 的 jQuery。这是我当前的 gulpfile:

var Gulp = require("gulp");

var Browserify = require("browserify");
var Buffer = require("vinyl-buffer");
var Rename = require("gulp-rename");
var Source = require("vinyl-source-stream");
var Tsify = require("tsify");
var Uglify = require("gulp-uglify");

var Manifest = require("./package.json");

Gulp.task("build-Debug", function () {
return Browserify({
debug: true,
standalone: Manifest.name
})
.add(Manifest.main)
.plugin(Tsify)
.bundle()
.on("error", function (error) { console.error(error.toString()); })
.pipe(Source(Manifest.name + ".js"))
.pipe(Buffer())
.pipe(Gulp.dest("./dist"));
});

捆绑的 JS 文件包含在我的网站中,一切正常。我只是缺少一件事:在某些网站上,我需要定义一些不应成为库一部分的自定义 JS。例如,这些自定义脚本应该能够使用 jQuery,但它不能,因为它无法从包外部访问。

现在,我可以再次包含它,但这对我来说没有意义。所以我想知道:

有没有一种方法可以让我从包外部访问 package.json 中的所有依赖项,以便我能够调用

$("#my_id")....

在我的自定义客户端脚本中?

最佳答案

您可以使用Browserify的require将模块公开为 external requires 的方法:

return Browserify({
debug: true,
standalone: Manifest.name
})
.add(Manifest.main)
.require("some-module") // Some module in node_modules that you want to expose.
.plugin(Tsify)
.bundle()
...

您将在 <script> 中获得该模块像这样的元素:

<script>
var someModule = require("some-module");
/* ... */
</script>

要验证这是否确实有效,您可以使用以下文件进行测试:

  • build.js

    const browserify = require("browserify");
    const path = require("path");

    browserify("app.js")
    .require("jquery")
    .bundle()
    .pipe(process.stdout);
  • app.js

    const jquery = require("jquery");
    console.log("Hello, world.")
  • index.html

    <!doctype html>
    <html>
    <head>
    <title>so-41095676</title>
    </head>
    <body>
    <script src="./bundle.js"></script>
    <script>
    console.log(require("jquery"));
    </script>
    </body>
    </html>

在目录中创建文件并运行以下命令:

npm install browserify jquery
node build.js > bundle.js

然后打开index.html您应该会看到 jQuery 函数记录到控制台。

关于javascript - 使所需的依赖项可以从包外部访问,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41095676/

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