我有一個MongoDb 學生集合。一個學生可以有多個課程(opl),其中包含開始和結束。 我用貓鼬創造server.js REST接口:更新日期在mongodb與angularJS和輸入類型=「日期」
//adres Schema
var adresSchema = new mongoose.Schema({
gemeente: String,
post: Number,
straat: String
})
//opl Schema
var oplSchema = new mongoose.Schema({
oplcode: Number,
geslaagd: Boolean,
startdatum: Date,
einddatum: Date,
})
//Studenten Schema
var studentSchema = new mongoose.Schema({
voornaam: String,
familienaam: String,
email: String,
adres: adresSchema,
foto: String,
ikl: Number,
opl: [oplSchema],
rijksreg: String,
gender: String,
tel: [String]
}, {collection:"studenten"})
來查詢一個學生,我用這個路徑上的型號:
/GET /api/studenten/:id 1 enkele student by id
apiRouter.get('/studenten/:id', function(req, res) {
return studentModel.findById(req.params.id,function(err, student) {
if (!err) {
res.send(student);// 1 student
}
else {
return console.log(err);
}
})
})
我的問題是如何使用Angular和需要Date()對象的HTML5輸入類型=「date」來顯示startdatum和einddatum日期? 我用這樣一個角度的服務創造了$範圍:在學生編輯控制器我填的是$範圍與服務
.factory('studentService',['$resource', function($resource){
var urlBase = "api/studenten";
var studentResource = $resource(
urlBase + '/:_id',
{_id: '@_id'},
{update: {method:'PUT'}
}
)
return studentResource;
}])
然後:
.controller('StudentEditCtrl', ['$scope', '$routeParams', 'studentService', 'opleidingService','$location',
function ($scope, $routeParams, studentService, opleidingService, $location) {
//update student and his courses (opl)
$scope.subtitel = "Update student";
$scope.student = studentService.get({}, {'_id': $routeParams._id});
//save
$scope.save = function (student) {
if ($scope.student._id) {
//update
console.log("updating student " + student.familienaam);
studentService.update({_id: $scope.student._id}, $scope.student);
}
else {
//new student
$scope.student.$save();
}
$location.path('/studenten');
}
//更多的方法,有些事情離開了
我如何使用我的$ scope.student.opl.startdatum dateStrings(ISODates)創建一個Date對象在
使用<input type="date" class="form-control" ng-model="opl.startdatum " />
這樣它的值是一個ISO字符串,我可以用它來更新課程日期。 我一直在讀自己愚蠢的,但沒有任何人顯示如何將Mongoose ISOString轉換爲Date對象...所有示例都以一個新的Date()對象開始,它們自己創建。 $ scope.student.opl不允許我將日期更改爲日期對象。我似乎無法添加一個字段。過濾器不起作用。 其實這下面正確顯示的日期,但它拋出了錯誤的整數和更新值爲空:
<input type="text" class="form-control" ng-model="opl.einddatum" value="{{opl.einddatum | date:'yyyy-MM-dd'}}" />
使用像
<input type="date" class="form-control" ng-model="makeDate(opl.startdatum) " />
的方法也不管用。我看着angular-ui-bootstrap,但這裏是一樣的:你需要一個Date對象。
我可能錯過了重要的戰略點這裏,但我希望得到一些幫助,給我看我的錯誤,謝謝,
月
嗨庫馬爾,這does'nt工作,因爲我的服務返回$資源,這是異步的:我不能直接編輯$ scope.student。 所以我的問題歸結爲:我如何編輯/更改/添加到異步資源之前(或之後)我填充它的範圍? – user3683637