0
我正在使用NextJs构建应用程序。我有两个用于生产和开发的不同URL,我想访问客户端环境的相应URL。我跟着这guide但我的PROCESS.ENV.API_URL在开发中是空的。nextjs的生产URL
这里是我的文件:
.ENV:
API_URL=https://my-staging-url.com
.env.production:
API_URL=https://my-production-url.com
.babelrc:
{
"presets": [
"next/babel"
],
"env": {
"development": {
"plugins": ["inline-dotenv"]
},
"production": {
"plugins": ["transform-inline-environment-variables"]
}
}
}
环境变量的用法:
import 'isomorphic-fetch';
export const SET_QUERY = 'SET_QUERY';
export const CLEAR_SEARCH = 'CLEAR_SEARCH';
export const START_FETCHING_SEARCH = 'START_FETCHING_SEARCH';
export const SET_SEARCH_RESULTS = 'SET_SEARCH_RESULTS';
export const FETCHING_SEARCH_FAILED = 'FETCHING_SEARCH_FAILED';
export const getSearch = value => {
const url = `${process.env.API_URL}search?q=${value}`; // THIS IS EMPTY
console.log(url);
return fetch(url);
};
// Implement search action
export const doSearch = query => dispatch => {
dispatch({ type: START_FETCHING_SEARCH });
return dispatch => {
return getSearch(query).then(response => {
dispatch({ type: SET_SEARCH_RESULTS });
},() => {
dispatch({ type: FETCHING_SEARCH_FAILED });
});
};
};
export const clearSearch =() => dispatch => {
return dispatch({ type: CLEAR_SEARCH })
};
希望帮助,干杯!