我想使用Firebase模块“Firebase.ServerValue.TIMESTAMP”将服务器生成的时间戳保存到firebase服务器上。
如何配置将Firebase导入为angular2项目中的模块。
我正在使用Angular2,angular-cli,angularFire2等。以下是配置设置。
System-config.ts
/** Map relative paths to URLs. */
const map: any = {
firebase: 'vendor/firebase/lib/firebase-web.js',
angularfire2: ' vendor/angularfire2'
};
/** User packages configuration.*/
const packages: any = {
angularfire2: {
defaultExtension: 'js',
main: 'angularfire2.js'
}
};
角-CLI-build.js
/* global require, module */
var Angular2App = require('angular-cli/lib/broccoli/angular2-app');
module.exports = function(defaults) {
return new Angular2App(defaults, {
vendorNpmFiles: [
'systemjs/dist/system-polyfills.js',
'systemjs/dist/system.src.js',
'zone.js/dist/**/*.+(js|js.map)',
'es6-shim/es6-shim.js',
'reflect-metadata/**/*.+(js|js.map)',
'rxjs/**/*.+(js|js.map)',
'@angular/**/*.+(js|js.map)',
// below are the AngularFire entries
'angularfire2/**/*.js',
'firebase/lib/*.js'
]
});
};
答案 0 :(得分:6)
使用Angularfire2,Angular 2和angular-cli,以下解决方案对我有用。
首先,确保使用以下命令导入firebase:
import * as firebase from 'firebase';
接下来,使用获取时间戳的旧方法,例如:
let dateNow = firebase.database.ServerValue.TIMESTAMP;
console.log(dateNow);
最后,打开src / typings.d.ts并添加:
declare namespace firebase.database.ServerValue {
let TIMESTAMP: any;
}
最后一部分是我的诀窍,与大多数使用OP特定设置的解决方案不同。
答案 1 :(得分:1)
对于旁路方式,您可以使用{'.sv': 'timestamp'}
db.object('path').set({ timestamp: {'.sv': 'timestamp'}}) // angular
firebase.database.ServerValue.TIMESTAMP
== {'.sv': 'timestamp'}