你需要分配那个id
对象的属性,例如
item = { id : 4 }
假设你有一个text-box
用户想要通过在其中插入新项目的名称并单击提交来保存新项目。
我们还假设您正在使用MongoDB
物品的集合,其中只有id
为简单起见,字段。
为了让事情顺利进行,您应该采取以下措施。
确保您正在导入bodyParser
var bodyParser = require('body-parser');
HTML - 使用自定义 ID 保存新项目
<div class="form-group">
<label for="id">ID</label>
<input type="text" class="form-control" id="id" ng-model="ItemController.formData.id">
</div>
<button type="submit" ng-click="ItemController.createItem()" >Submit</button>
角度部分 - ItemController.js
'use strict';
angular
.module('myApp')
.controller('ItemController', ItemController);
function ItemController($http) {
var vm = this;
/** Creates a New Marker on submit **/
vm.createItem = function() {
// Grabs all of the text box fields
var itemData = {
id : vm.formData.id
};
// Saves item data to the db
$http.post('/api/kill', itemData)
.success(function(response) {
if(response.err){
console.log('Error: ' + response.err);
} else {
console.log('Saved '+response);
}
});
};
}
路由处理-routes.js
var ItemFactory = require('./factories/item.factory.js');
// Opens App Routes
module.exports = function(app) {
/** Posting a new Item **/
app.post('/api/kill', function(req, res) {
ItemFactory.postItem(req).then( function (item) {
return res.json(item);
});
});
};
发布到 MongoDB - item.factory.js
var Item = require('../models/item-model');
exports.postItem = postItem;
function postItem(item) {
return new Promise( function (resolve, reject) {
var newItem = new Item(item.body);
newItem.save(function(err) {
if (err){
return reject({err : 'Error while saving item'});
}
// If no errors are found, it responds with a JSON of the new item
return resolve(item.body);
});
});
}
如果你试试console.log()
在我传递该项目的不同代码片段上,您可以正确地看到一个对象id property
.
我希望我有所帮助。