node.js - 在 Gulp 文件中以编程方式获取 BrowserSync 外部 URL,以便我可以将其传递给外部 Node 脚本?

标签 node.js gulp browser-sync

我希望能够将 browserSync 外部 URL 作为我的 gulp 文件中的外部 Node 脚本的参数发送。如何通过 browserSync 对象(或其他方式)获取该外部 URL?

var gulp = require('gulp');
var shell = require('gulp-shell');
var browserSync = require('browser-sync').create();

gulp.task('default', ['browser-sync', 'config']);

gulp.task('browser-sync', function() {
    browserSync.init({
        proxy: "localhost:8024",
        open: "external"
    });
});

gulp.task('config', shell.task([
    "node scripts/someNodeScript.js browserSync.externalURL"
]));

更新

根据下面 @sven-shoenung 的出色回答,我稍微调整了他的解决方案并成功使用了这个:

var gulp = require('gulp');
var browserSync = require('browser-sync').create();
var spawn = require('child_process').spawn;

var externalUrl;

var browserSyncDone = function () {
    spawn('node', ['scripts/someNodeScript.js', externalUrl], {stdio:'inherit'});
};

gulp.task('default', ['browser-sync']);

gulp.task('browser-sync', function() {
    browserSync.init({
        proxy: "localhost:8024",
        open: "external"
    }, function() {
        externalUrl = browserSync.getOption('urls').get('external');
        browserSyncDone();
    });
});

最佳答案

您可以使用browserSync.getOptions('urls')获取 Map所有访问 URL。它返回类似这样的内容:

Map { 
  "local": "http://localhost:3000", 
  "external": "http://192.168.0.125:3000", 
  "ui": "http://localhost:3001",  
  "ui-external": "http://192.168.0.125:3001" 
}

请注意,只有在 browser-sync 成功初始化后才可用,因此您需要将回调函数传递给 browserSync.init() 否则您会过早地尝试获取该值。

出于同样的原因,您将无法使用gulp-shellshell.task() 将在 before browser-sync 初始化之前设置,因此 browserSync.getOptions('urls') 尚不可用。

我建议你使用标准的nodejs child_process.spawn()相反。

var gulp = require('gulp');
var browserSync = require('browser-sync').create();
var spawn = require('child_process').spawn;

var externalUrl;

gulp.task('default', ['browser-sync', 'config']);

gulp.task('browser-sync', function(done) {
  browserSync.init({
    proxy: "localhost:8024",
    open: "external"
  }, function() {
    externalUrl = browserSync.getOption('urls').get('external');
    done();
  });
});

gulp.task('config', ['browser-sync'], function(done) {
  spawn('node', ['scripts/someNodeScript.js', externalUrl], {stdio:'inherit'}).on('close', done);
});

关于node.js - 在 Gulp 文件中以编程方式获取 BrowserSync 外部 URL,以便我可以将其传递给外部 Node 脚本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40916025/

相关文章:

node.js - 尝试解析请求正文时,POST 请求挂起(超时),在 Firebase Cloud Functions 上运行 Koa

javascript - 异步等待 + Gulp - GulpUglifyError : unable to minify JavaScript?

node.js - 浏览器同步和代客安全

javascript - Node.js MYSQL解析错误

node.js - Typescript 版本与 Node 版本

node.js - Ubuntu 14 上的 Node 和 NVM 安装损坏。有什么想法我应该做什么吗?

node.js - Liferay主题创建: Error During gulp build and gulp deploy

angularjs - 在执行 gulp build :dist 时设置代理或后端 URL

断点后浏览器刷新

javascript - Gulp 仅在浏览器刷新后加载 CSS