Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
Help us understand the problem. What is going on with this article?

browserify + npmでReactを使う場合はNODE_ENVを設定するとよい

More than 5 years have passed since last update.

Reactの内部には次のようなコードがいたるところにある。

if ("production" !== process.env.NODE_ENV) {
  console.log('debug message');
}

あらかじめビルド済みのreact.min.jsとかを使う場合はすでにproductionモードでビルドされてるので気にしなくていいけど、browserifyで自分でReactをビルドする場合はNODE_ENVを設定する必要がある。

のでproductionでは次のように環境変数を設定して実行するとよい。

$ NODE_ENV=production browserify src/app.js -o bundle.js

このようにしてビルドすると、Reactがenvifyというtransform packageを使っているため、次のように変換される。

if ("production" !== "production") {
  console.log('debug message');
}

さらにこれをuglifyにかけてminifyするとここに到達することはないdead codeということでコード自体を削ってくれる。

hokaccha
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away