gpt4 book ai didi

ruby-on-rails - 为什么我的 Angular 应用程序不向我的 Entangle rails Controller 发送参数?

转载 作者:IT王子 更新时间:2023-10-29 06:14:05 26 4
gpt4 key购买 nike

为了了解实时应用程序,我正在尝试使用 Entangled 创建一个基本的留言板.

我有一个 Angular 应用程序和一个带有包含 Entangled::Controller 的消息 Controller 的 Rails 后端。当从 Angular 应用程序提交表单时,此 Rails Controller 成功接收到请求 - 使用 Entangled 提交表单。 (点击提交后,Angular Controller 中会触发一个函数,该函数应在后端创建一条新消息并更新所有订阅该后端的客户端。)

我知道 Angular 函数在点击提交时被触发,我知道函数从表单接收到正确的信息:console.log($scope.message) 显示 {socket :“ws://message-board-olliehm.c9users.io:8080/messages”,用户名:“ggg”,内容:“gggggg” 我在用户名字段中提交“ggg”和“gggggg” "在内容字段中。

问题是这些字段没有到达 Rails Controller 。当我单击提交时,在 Rails Controller 中触发了正确的操作,但参数不包含正确的信息: def create 中的 p params 返回 { “controller”=>“messages”、“action”=>“create”,没有“message”散列,也没有“username”或“content”键。

我不知道 Entangled 对用户名和内容字段做了什么。

Redis 对我来说是新手,所以我不确定是否存在问题。我安装了 Redis,redis-server 正在按照 Entangled 的要求运行。我有一个如下所示的 redis 初始化程序,它在 Rails 控制台中成功连接并让我将数据放入数据库:

$redis = Redis.new(:host => $IP, :port => 6379)

这是我的 Angular Controller :

var controllers = angular.module('controllers');

controllers.controller('MessageboardController', ['$scope','Message', function($scope,Message){

$scope.message = Message.new();

$scope.post = function() {
console.log($scope.message);
$scope.message.$save(function() {
$scope.$apply(function() {
$scope.message = Message.new();
});
});
};

Message.all(function(err, messages) {
$scope.$apply(function() {
$scope.messages = messages;
});
});

}]);

这里的消息是指这个工厂:

messageboard.factory('Message', function(Entangled){
return new Entangled('ws://message-board-olliehm.c9users.io:8080/messages');
});

这是我的 Angular View :

<h1>Messageboard</h1>

<section class='row' ng-if='messages'>
<ul>
<li ng-repeat='message in messages'>
{{message.username}}
{{message.content}}
</li>
</ul>
</section>

<section class='row'>
<form ng-submit="post()">
<div class='form-group'>
<label for='username'>Message as</label>
<input ng-model='message.username' name='username' type='text'>
</div>
<div class='form-group'>
<input ng-model='message.content' name='message' type='text' placeholder='Write your message here'>
</div>
<div class='form-group'>
<input type="submit">
</div>
</form>
</section>

非常感谢您的建议 - 这导致了长期的挫败感,我非常渴望着手创建具有实时更新的内容。

最佳答案

经过反复试验,我意识到后端 Controller 显然接收到的空参数具有误导性。只要我对 Controller 接收到的原始参数执行以下操作,参数就会正确到达并创建并广播一个新的消息对象:

params.require(:message).permit(:content,:username)

即正是您对按预期到达的表单参数所做的事情。对我来说奇怪的是 params 不包含“消息”哈希,直到您需要如上所述的哈希。我想这与它不是常规的 HTTP 请求有关,但将不胜感激......

关于ruby-on-rails - 为什么我的 Angular 应用程序不向我的 Entangle rails Controller 发送参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39231320/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com