Webpack使用心得——变量注入

应用场景:开发环境api地址:test.api.ctrip.com,生产环境api地址:api.ctrip.com,我们需要根据不同的环境来修改不同的地址,手动维护很麻烦,于是有人想到了通过Node注入一些参数(process.env.NODE_ENV=production)来表明此时是生产环境,这种判断机制在NodeJS的程序中可以直接使用,但是前端是不能直接获取process这个变量的?这个时候,webpack的一款插件可以帮助我们完美解决这样的烦恼,它就是:DefinePlugin

关于在webpack中如何使用插件,在这里就不赘述了,下面只介绍DefinePlugin插件的相关api:

1、定义:

new webpack.DefinePlugin({
  // 传入配置项
})


2、配置项:

2.1、关于配置项的官方文档说明:

每个传进 DefinePlugin 的键值都是一个标志符或者多个用 . 连接起来的标志符。

  • 如果这个值是一个字符串,它会被当作一个代码片段来使用。
  • 如果这个值不是字符串,它会被转化为字符串(包括函数)。
  • 如果这个值是一个对象,它所有的 key 会被同样的方式定义。
  • 如果在一个 key 前面加了 typeof,它会被定义为 typeof 调用。

这些值会被内联进那些允许传一个代码压缩参数的代码中,从而减少冗余的条件判断。

2.2、举例说明:

a、"process.env":"'product'"这段代码可以让我们在前端直接使用:process.env,并且值为'product'

注意:这里"'product'"的写法不能把里面的引号丢了,如果丢了,会当成product变量来处理,有了就当成'product'字符串来处理

 

转载于:https://my.oschina.net/chengxiancheng/blog/1585941

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值