小编Joe*_*lum的帖子

为什么我的 Flash.now 在渲染后不输出?

我有一个小问题,我似乎无法弄清楚。

常规闪光灯的工作原理与预期一样。

flash[:test] = 'Blarrgh'
redirect_to etcs_url
Run Code Online (Sandbox Code Playgroud)

将显示“Blarrgh”,因为我的 application.html.erb 中有此代码

      <% if flash[:test] %>
        <%= flash[:test] %>
      <% elsif flash.now[:test] %>
        <%= flash.now[:test] %>
      <% end %>
Run Code Online (Sandbox Code Playgroud)

我很确定显示 flash.now[:test] 消息的方式只是 flash[:test],但我在底部添加了 elsif 以防万一,因为事情不起作用。

出于某种原因,当我这样做时

flash.now[:test] = 'Blarrgh'
render :edit
Run Code Online (Sandbox Code Playgroud)

什么也没有显示出来。但是,当我将“失败”语句放入视图中然后检查这些值时,flash[:test]/flash.now[:test] 将具有正确的值。例如,['Etc不能为空']

我尝试检查常见错误:没有 CSRF 令牌、隐藏重定向、flash.now b4 渲染、使用 form_with 而不使用 local:true,但是查看我的日志,没有这样的问题。我包含了 CSRF 令牌,我的日志路径是

In logs:
patch /etc/1
(Commit fails, rolls back)
renders application.html.erb which yields etcs/edit.html.erb which renders etcs/_form.html.erb, then renders rest of etcs/edit.html.erb
Run Code Online (Sandbox Code Playgroud)

我将 flash.now b4 放在渲染中。我也没有使用像 form_with 这样的 Rails 辅助函数。

ruby ruby-on-rails render flash-message hotwire

6
推荐指数
1
解决办法
1560
查看次数

Chrome扩展程序在Background.js中注册事件

我的扩展需要为其用户提供一些服务,其中一部分工作是收听制表符创建事件.我在popup.js中拥有所有的javascript并自我调用chrome.tabs.onCreated.addListener(function(tab){

事情是扩展只监听标签创建事件,如果用户点击扩展符号(如果他打开扩展名因此激活popup.js),并且如果关闭poupup屏幕,则所有事件监听都会停止.(我通过写入控制台来验证它,如果你停下来思考它就有意义了)我的问题是:我希望在整个扩展的生命中听取事件(换句话说,自用户打开chrome以来),而不仅仅是用户弹出扩展名.

我知道有一个叫做背景页面的东西,我应该尝试将整个代码移到那里吗?我这背景页的常规做法是什么?只是事件监听器依赖于更多的功能和更多的对象,似乎我的代码几乎都会去那里.popup.js几乎什么都没有.另一件事是我不确定是否可以在'domcontentloaded'事件被触发之前在后台页面中注册事件(并且此事件仅在用户弹出扩展时触发).

任何帮助,将不胜感激!

javascript javascript-events google-chrome-extension

5
推荐指数
1
解决办法
2120
查看次数

chrome扩展命令行通信

无论如何,我是否可以通过命令行\其他进程与我的 chrome 扩展进行通信?如果我的扩展可以从脚本\命令行获取命令来调用我的扩展上的函数,那么我需要我的扩展。我正在寻找类似套接字的东西,但由于扩展是在 javascript 中内置的,这似乎不可能(并且在 chrome 中传递的整个类似套接字的消息只允许您在自己的页面或其他扩展之间进行通信,而不是其他进程之间进行通信)。

javascript google-chrome google-chrome-extension

5
推荐指数
1
解决办法
620
查看次数

PHP if(变量)

在各种PHP教程中,我看到了这种语法 -

if ($_POST) {
  do something
}
Run Code Online (Sandbox Code Playgroud)

我想知道这是否等同于isset或!(空)(任一个)或具有不同的属性.

php

5
推荐指数
2
解决办法
233
查看次数

Google Chrome扩展程序简单的邮件传递错误

我正在尝试使用一个消息界面在我的弹出窗口之间传递消息到背景页面(我使用类似于Google示例中的代码).

弹出:

chrome.extension.sendMessage( {msg: "this is popup's msg"}, function(b){
    alert('this is popups callback func' +b.backgroundMsg);
});
Run Code Online (Sandbox Code Playgroud)

这就是我在background.js中监听(和回复)的方式:

chrome.extension.onMessage.addListener(function(msg, sender, sendResponse) {
    sendResponse({backgroundMsg: "this is background msg"});
});
Run Code Online (Sandbox Code Playgroud)

现在,当我检查控制台中的所有内容时,消息交换正常但我收到以下错误:

Error in event handler for 'undefined': Cannot call method 'disconnect' of null TypeError: Cannot call method 'disconnect' of null
    at chromeHidden.Port.sendMessageImpl (miscellaneous_bindings:285:14)
    at chrome.Event.dispatch (event_bindings:237:41)
    at Object.chromeHidden.Port.dispatchOnMessage (miscellaneous_bindings:250:22)
Run Code Online (Sandbox Code Playgroud)

有什么想法吗?

javascript-events google-chrome-extension

4
推荐指数
1
解决办法
4138
查看次数

Node.js非阻塞性质

我是node.js的新手,仍在努力理解它背后的哲学.据我所知,node.js只在一个进程中运行,而不是php,它为每个请求打开一个进程\线程.虽然你可以说Node对于i/o来说是"非阻塞的",但它阻止了请求(由于每个新请求没有新线程,所以请求堆积起来)理论上如果你编写了一个node.js应用程序这对你遇到麻烦的每个请求都没有快速处理.

我的问题是 - 如何判断某个请求的处理时间是否过长,以至于它会阻止所有其他请求太长时间并阻碍我的应用程序的性能?

我知道服务器上的所有"重"动作(db查询,文件系统搜索)都是通过回调完成的,因此不能阻塞节点.但是,如果服务器同步完成的所有其他操作处理请求只需要太长时间呢?

例如,服务器需要在响应中写入大量的html.那么会发生什么?

节点程序员如何知道他是否对某个请求(以阻塞方式)做得太多,是经验,直觉还是有关于如何做到这一点的明确指南?

javascript node.js

4
推荐指数
1
解决办法
808
查看次数

如何在turbo_frame中重定向表单?

我需要添加一个按钮来保留以下表单的数据,但是当按下它时会重置视图并保留在其中,而不重定向到控制器的索引,我尝试过 ajax 调用,但我不知道为什么不适合我。我该如何给出解决方案并添加保存并继续的按钮?

<%= turbo_frame_tag dom_id(taxonomy) do %>
  <%= form_with(model: [:admin, taxonomy], id: dom_id(taxonomy)) do |form| %>
<div class="box">
  <div class="field is-horizontal">
    <div class="field-body">
      <div class="field">
        <div class="control is-expanded is-relative">
          <%= form.text_field :name, placeholder: true, class: "input mt-5" %>
          <%= form.label :name, class: "label-hidden required" %>
        </div>
      </div>

      <div class="field is-narrow">
        <div class="control mt-5">
          <%= form.submit nil, class: "button is-primary" %>
          <%= link_to "#{ t '.cancel'}", admin_taxonomies_path, class: "button is-light" %>
        </div>
      </div>
    </div>
  </div>
</div>
<% end %>
<% …
Run Code Online (Sandbox Code Playgroud)

ruby ruby-on-rails ruby-on-rails-6.1 hotwire-rails turbo

4
推荐指数
1
解决办法
4589
查看次数

Node.js阻止自然

这是我之前的问题Node.js Non Blocking Nature.我仍然感觉不到我完全理解Node.js正在发生的事情.让我们说Node收到了一个用户上传大文件的请求.现在我们说我们把代码放在回调中处理文件,从而使它异步.接下来发生什么 ?让我们说回调被放入Node.js应用程序需要处理的大量事件列表中,所以到目前为止它并没有阻塞.但是在某些时候,回调会从事件循环中拉出来并且它的代码开始运行(上传或下载文件,无论如何).现在怎么办 ?Node.js应用程序现在被阻止吗?如果是这样 - 它如何不破坏应用程序的性能,如果不是 - 谁负责'跳' 不同的事件和请求之间?我们知道在apache或类似服务器中有特殊代码来处理所有线程(对它们进行计时),这样就没有线程会阻塞所有其他线程.但是,在Node中,我知道,有一个事件循环.当文件I\O完成时,它的回调会神奇地返回ready文件.尽管如此,服务器仍然必须做I\O,没有逃避!事件循环中的代码是否正在计时?例如,在不同事件之间跳转(callbacks..whatever),以便没有请求扼杀另一个事件?如果是这样,以什么方式?事件循环中的代码是否正在计时?例如,在不同事件之间跳转(callbacks..whatever),以便没有请求扼杀另一个事件?如果是这样,以什么方式?事件循环中的代码是否正在计时?例如,在不同事件之间跳转(callbacks..whatever),以便没有请求扼杀另一个事件?如果是这样,以什么方式?

javascript google-chrome v8 node.js

2
推荐指数
1
解决办法
2082
查看次数

停止网站目录列表

我对我正在开发的网站(在 Codeigniter 中)有点不满 - 当网站没有缓存在我的浏览器中并且我连接到它时,一两秒钟我看到我的根目录列表(在 1- 2 秒后列表停止,网站显示正常)。

我读过我可以尝试使用 .htaccess 文件来防止这种情况发生,所以我在第一行写了这个 -

IndexIgnore *
Run Code Online (Sandbox Code Playgroud)

但它没有帮助。有什么建议吗?

php .htaccess codeigniter web-applications

2
推荐指数
1
解决办法
1110
查看次数

JSON.parse是否隐式调用?

我有JSON从我的服务器进入我的javascript就像这样 -

<script>
   var resp = <?php  echo getjsonFromServer() . ';'?> 
   resp=JSON.parse(resp);
   displayStats(resp);
</script>
Run Code Online (Sandbox Code Playgroud)

这会产生错误'SyntaxError:Unexpected token o',当我检查控制台时,我看到响应已经被JSON解析.意思是我不应该尝试JSON.parse已经解析过的答案.

我的问题是 - 怎么样?谁为我解析了我的JSON?每当我从服务器获得JSON时,我习惯调用JSON.parse,例如ajax调用.为什么在这里不一样?

注意 - 我的PHP是这样的

header('"Content-Type":application/json');
$js = json_encode($js);
echo $js;
Run Code Online (Sandbox Code Playgroud)

javascript php json

1
推荐指数
1
解决办法
156
查看次数