V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
07jfxiao
V2EX  ›  Node.js

Nodejs 代码中为 Gulp Webpack 等 Iterm2 窗口添加端口识别标记

  •  
  •   07jfxiao · 2016-06-22 20:30:28 +08:00 · 2466 次点击
    这是一个创建于 3132 天前的主题,其中的信息可能已经有所发展或是发生改变。

    缘由

    最近两年来经常在 Iterm2 中打开好几个窗口运行 Gulp, Webpack 等,在每个窗口布满 log 后,想找到哪个窗口是干嘛的都有些困难,更不用说这个窗口占用了哪个端口。

    所以得有方法标记每个窗口是哪个占用哪个端口号,在跑啥。

    解决方案

    一个 npm 包

    npm i set-iterm2-badge

    两行代码

    var setIterm2Badge = require('set-iterm2-badge')
    setIterm2Badge('官网 8080')
    

    看看效果:

    多个 Iterm2 窗口切换时效果:

    1

    工具集成

    Gulp 和 Browser Sync

    如果使用 Gulp 和 Browser Sync ,要注意 Browser Sync 的 port 并不一定是传入的 port 。 比如下面这个例子,如果 8080 被其他进程占用了, bs 可能会 8081 8082 等一路试下去哪个可用用哪个。所以得使用回调的对象调用最终端口 bs.options.getIn(['port']) 来处理

    var bs = require('browser-sync').create();
    bs.init({
        port: 8080,
        /*你的其他配置*/
    }, function(err, bs) {
        setIterm2Badge(bs.options.getIn(['port']));
    });
    

    Webpack Dev Server

    要在 Webpack 集成使用这个功能,得使用 'webpack-dev-middleware' 来运行 Webpack 。示例

    var devConfig = require(path.resolve(__dirname, './dev'));
    var app = express()
    var compiler = webpack(devConfig);
    app.use(require("webpack-dev-middleware")(compiler, {
        publicPath: devConfig.output.publicPath
    }));
    var port = 8078
    setIterm2Badge('官网 ' + port)
    app.listen(port, '0.0.0.0', function (err) {
      if (err) {
        console.log(err)
        return
      }
      console.log('Listening at http://0.0.0.0:' + port)
    })
    

    本文同步发布在我的博客: http://zaishanda.com/post/set-iterm2-badge

    3 条回复    2016-06-23 15:07:07 +08:00
    cxbig
        1
    cxbig  
       2016-06-22 21:03:18 +08:00
    支持一下,虽然我用 tmux 可以轻易的设置窗口名字。
    07jfxiao
        2
    07jfxiao  
    OP
       2016-06-23 13:44:54 +08:00
    @cxbig 本地用 tmux 会不会太累了,创建个新窗口得按几次键。
    cxbig
        3
    cxbig  
       2016-06-23 15:07:07 +08:00
    @07jfxiao <prefix>+<c>是默认的,还可以绑定快捷键直接创建 window ,改名也可以。不觉得有啥繁琐。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2765 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 12:57 · PVG 20:57 · LAX 04:57 · JFK 07:57
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.