我最近刚开始使用打字稿
我正在将JavaScript代码移至打字稿。在我的JS代码中,我有这样的东西
export const envVar = {
SOCIAL_URL: false,
BASE_CONFIG_URL: '', //we change it based on the request
BASE_CONFIG_CLIENT_WEB_URL: base_config.client_url || 'http://localhost:3000',
DB_HOST: db_settings.db_host || 'localhost',
DB_USER: db_settings.db_user || 'root',
APP_URL: base_config.app_url || 'blle://',
DB_PASSWORD: db_settings.db_password || '',
DB_DATABASE: db_settings.db_database || 'blale',
DB_CONNECTION_NAME: db_settings.connection_name || '',
FIREBASE_DATABASE_URL: db_settings.firebase_datbase_url,
FACEBOOK_APP_ID: facebook.app_id || '',
FACEBOOK_APP_SECRET: facebook.app_secret || '',
FACEBOOK_REDIRECT_URL_SOCIAL: facebook.redirect_url_social || '',
FACEBOOK_REDIRECT_URL_AUTH: facebook.redirect_url_auth || '',
FACEBOOK_REDIRECT_URL: function() {
return this.SOCIAL_URL ? this.FACEBOOK_REDIRECT_URL_SOCIAL : this.FACEBOOK_REDIRECT_URL_AUTH
},
TWITTER_CONSUMER_KEY: twitter.api_key || '',
TWITTER_REDIRECT_URL_AUTH: twitter.redirect_url_auth || '',
TWITTER_REDIRECT_URL_SOCIAL: twitter.redirect_url_social || '',
TWITTER_APP_SECRET: twitter.app_secret_key || '',
TWITTER_REDIRECT_URL: function() {
return this.SOCIAL_URL ? this.TWITTER_REDIRECT_URL_SOCIAL : this.TWITTER_REDIRECT_URL_AUTH
},
JWT_SESSION_DURATION: jwt_config.session_duration || '7d',
JWT_ISSUER: jwt_config.issuer || 'blle',
JWT_SECRET: jwt_config.secret || '933dnz82'
}
将此内容从module.exports
移至export const
。现在,如何使用另一个.ts文件?我最初做过这样的事情
import * as envVar from "./../config"
const { JWT_SECRET, JWT_ISSUER, JWT_SESSION_DURATION } = envVar
但这给出了以下错误
类型'typeof'上不存在属性'JWT_SESSION_DURATION'
答案 0 :(得分:1)
由于您正在执行命名导出,因此导入将收到一个包含envVar
作为属性之一的对象。
因此您可以执行以下操作。
import { envVar } from "./../config"
OR
import * as envVar from "./../config"
const { JWT_SECRET, JWT_ISSUER, JWT_SESSION_DURATION } = envVar.envVar
如果要使用现有的导入,则必须将命名的导出更改为默认导出。
const envVar = {....};
export default envVar;
答案 1 :(得分:0)
// GlobalConfig .ts
export namespace GlobalConfig {
export var JWT_SESSION_DURATION = { myValue: "4" }
export const JWT_SECRET = "asasasasas"
}
然后您可以在另一个这样的文件中使用它。请注意,这是执行此操作的众多方法之一。
//MyCode.ts
import { GlobalConfig } from "./GlobalConfig";
export class SomeComponent {
current_jwt = "";
constructor() {
// some init code
this.current_jwt = GlobalConfig.JWT_SESSION_DURATION.myValue;
}
ngOnInit() {
// something
console.log(this.current_jwt);
console.log(GlobalConfig.JWT_SECRET);
}
}