- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
现在我有这个表格:
<form ng-submit = "submit()"ng-controller = "formCtrl">
<input ng-model="formData.stickie" type="text" id="sticky_content" />
<button type="submit" id="add_sticky" value="add a new stickie!">new sticky</button>
</form>
由这个模型控制:
app.controller('formCtrl',function($scope,$http){
$scope.submit = function() {
$http.post('/api/stickies', $scope.formData)
**** somehow assign data to something useable by the function below???******
})
.error(function(data){
console.log('Error: ' + data);
});
};
});
我希望能够在这里使用发布的数据:
app.post('/api/stickies',function(req,res){
var test = formData.stickie; //returns undefined for sticky and for formData.stickie
db.run("INSERT INTO stickies (data) VALUES (?)", [ test ]);
});
总而言之,我正在尝试将 $scope.formData 变量传递到我的 server.js 文件中,以便它可以在我的 app.post 函数中使用(并插入到数据库中)
编辑:根据下面给出的答案更新代码:当我提交表单时,当前收到 `ReferenceError: formData is not Defined。
最佳答案
当你使用 ng-model
时,它是将你的表单组件绑定(bind)到使用特定名称的范围。这意味着
<input ng-model="stickie_text" type="text" id="sticky_content" />
将为您带来一个$scope.stickie_text
,其中包含您在'formCtrl'
Controller 中的组件的当前值。请记住这是一个双向绑定(bind):如果您更改该变量,您也会更改表单控件中的值。
让我们重构一下:
<form ng-submit="submit()" ng-controller="formCtrl">
<input ng-model="stickie_text" type="text" id="sticky_content" />
<button type="submit" id="add_sticky" value="add a new stickie!">new sticky</button>
</form>
此表单只有一个字段:stickie_text
。另一个是按钮。到目前为止,您的表单只有一个字段,该字段存储和读取指定名称($scope.stickie_text
)范围内的数据。
当您提交表单时,将调用您的 $scope.submit
函数:
$scope.submit = function() {
$http
.post('/api/stickies', {what: to, put: here})
.success(function(data){
//what to do here
})
.error(function(data){
console.log('Error: ' + data);
});
};
所以这是你的处理程序,最大的问题是:
请注意,我稍微更改了您的处理程序 - 放置评论并替换数据对象。
POST 数据必须匹配服务器端。所以如果你的 stickie 必须以 stickie
的名字在网络中飞行(这样,一个 req.body.stickie
表达式存在于服务器端),你的数据必须编写的是:{stickie: $scope.stickie_text}
。这是因为 stickie_text
是您在 View 中使用的名称,因此它是该字段将从中读取和写入的范围变量的名称。请记住在您的应用程序中安装 body 解析器
中间件。
我不太记得 nodejs,但如果我是对的,也许会做:
app.post('/api/stickies',function(req,res){
var test = req.body.stickie;
db.run("INSERT INTO stickies (data) VALUES (?)", [ test ]);
});
将执行此操作只要您使用来自客户端的相同数据 key 。您还应该在响应 (res
) 对象中写入一些内容,但这取决于您和 nodejs,以及您的首选方式(例如 res.write
)。
因此,我们将坚持使用相同的示例:
$scope.submit = function() {
$http
.post('/api/stickies', {stickie: $scope.stickie_text})
.success(function(data){
//what to do here? it's up to you and the data you write from server.
})
.error(function(data){
console.log('Error: ' + data);
});
};
对此进行测试,并检查您的数据库。
编辑 - @Kousha 建议 - 为你的表单数据使用一个实际的命名空间(正如你之前所说的 formData
- 请记住这是一个例子,你可以使用任何你想要的名字)。它是这样工作的:
为 ng-model
中的每个字段添加一个前缀,以便同一个对象保存表单数据。由于您只有一个字段,因此就足够了:
ng-model="formData.stickie"
我故意更改了变量名以匹配在 nodejs 服务器中等待的名称。不要忘记这一点,因为我将直接使用该对象作为数据。
$scope.formData
的最终值将是 {stickie: whatEverIsInTheInputField}
。如果我使用 ng-model="formDta.foo"
添加另一个字段作为绑定(bind),$scope.formData
的最终值将是 {stickie: whatEverIsInTheInputField, foo: otherFieldValue}
.
我直接在 http 请求中使用 $scope.formData
:
$scope.submit = function() {
$http
.post('/api/stickies', $scope.formData)
.success(function(data){
//what to do here? it's up to you and the data you write from server.
})
.error(function(data){
console.log('Error: ' + data);
});
};
虽然 formData
事先不存在于 $scope
中,但绑定(bind)在其下创建 stickie
之前隐式创建了它。
关于javascript - Angular : how to pass $scope variables into the Node. js 服务器。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25025426/
我正在学习构建单页应用程序 (SPA) 所需的所有技术。总而言之,我想将我的应用程序实现为单独的层,其中前端仅使用 API Web 服务(json 通过 socket.io)与后端通信。前端基本上是
当我看到存储在我的数据库中的日期时。 这是 正常 。日期和时间就是这样。 但是当我运行 get 请求来获取数据时。 此格式与存储在数据库 中的格式不同。为什么会发生这种情况? 最佳答案 我认为您可以将
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试使用backbone.js 实现一些代码 和 hogan.js (http://twitter.github.com/hogan.js/) Hogan.js was developed ag
我正在使用 Backbone.js、Node.js 和 Express.js 制作一个 Web 应用程序,并且想要添加用户功能(登录、注销、配置文件、显示内容与该用户相关)。我打算使用 Passpor
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我尝试在 NodeJS 中加载数据,然后将其传递给 ExpressJS 以在浏览器中呈现 d3 图表。 我知道我可以通过这种方式加载数据 - https://github.com/mbostock/q
在 node.js 中,我似乎遇到了相同的 3 个文件名来描述应用程序的主要入口点: 使用 express-generator 包时,会创建一个 app.js 文件作为生成应用的主要入口点。 通过 n
最近,我有机会观看了 john papa 关于构建单页应用程序的精彩类(class)。我会喜欢的。它涉及服务器端和客户端应用程序的方方面面。 我更喜欢客户端。在他的实现过程中,papa先生在客户端有类
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我是一个图形新手,需要帮助了解各种 javascript 2D 库的功能。 . . 我从 Pixi.js 中得到了什么,而我没有从 Konva 等基于 Canvas 的库中得到什么? 我从 Konva
我正在尝试将一些 LESS 代码(通过 ember-cli-less)构建到 CSS 文件中。 1) https://almsaeedstudio.com/ AdminLTE LESS 文件2) Bo
尝试查看 Express Passport 中所有登录用户的所有 session ,并希望能够查看当前登录的用户。最好和最快的方法是什么? 我在想也许我可以在登录时执行此操作并将用户模型数据库“在线”
我有一个 React 应用程序,但我需要在组件加载完成后运行一些客户端 js。一旦渲染函数完成并加载,运行与 DOM 交互的 js 的最佳方式是什么,例如 $('div').mixItUp() 。对
请告诉我如何使用bodyparser.raw()将文件上传到express.js服务器 客户端 // ... onFilePicked(file) { const url = 'upload/a
我正在尝试从 Grunt 迁移到 Gulp。这个项目在 Grunt 下运行得很好,所以我一定是在 Gulp 中做错了什么。 除脚本外,所有其他任务均有效。我现在厌倦了添加和注释部分。 我不断收到与意外
我正在尝试更改我的网站名称。找不到可以设置标题或应用程序名称的位置。 最佳答案 您可以在 config/ 目录中创建任何文件,例如 config/app.js 包含如下内容: module.expor
经过多年的服务器端 PHP/MySQL 开发,我正在尝试探索用于构建现代 Web 应用程序的新技术。 我正在尝试对所有 JavaScript 内容进行排序,如果我理解得很好,一个有效的解决方案可以是服
我是 Nodejs 的新手。我在 route 目录中有一个 app.js 和一个 index.js。我有一个 app.use(multer....)。我还定义了 app.post('filter-re
我正在使用 angular-seed用于构建我的应用程序的模板。最初,我将所有 JavaScript 代码放入一个文件 main.js。该文件包含我的模块声明、 Controller 、指令、过滤器和
我是一名优秀的程序员,十分优秀!