使用ajax在js.erb文件中未定义Gon变量

时间:2021-11-27 08:59:45

I have a highchart that is being rendered by a js.erb file in conjunction with the gon variable. The setup that I have is that a user will load a page and once the page is ready an ajax call will be made to a separate controller. The controller will handle the data needed, assign it to gon and will render the appropriate js.erb file with the data. However, I keep observing that gon is consistently undefined and the variables are not being sent to gon. I wonder if this has to do with ajax but here is my code and logic flow.

我有一个由js.erb文件和gon变量一起呈现的高图。我的设置是用户将加载页面,一旦页面准备好,将对单独的控制器进行ajax调用。控制器将处理所需的数据,将其分配给gon并将使用数据呈现相应的js.erb文件。但是,我一直在观察gon始终未定义且变量未发送到gon。我想知道这是否与ajax有关,但这是我的代码和逻辑流程。

Here is where the call originates

这是呼叫发起的地方

_vulnerabilites_per_version.html.haml

%script{:src => "https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"}
= Gon::Base.render_data


- vanity_url = project.vanity_url
:javascript
  $(document).ready(function() {
    $.ajax({
      url: "/p/#{vanity_url}/security.js"
    });
  })

#vulnerabilities{:style => "max-width: 405px; height: 300px; margin: 0 auto"}

The call goes then to the controller

然后呼叫转到控制器

class VulnerabilitiesController < ApplicationController

  before_action :set_project_or_fail
  before_action :set_best_project_security_set
  before_action :set_releases
  before_action :set_vulnerabilities

  def vulnerabilities_per_version
    gon.watch.release_versions = @releases.map { |r| r.version }
    puts gon.release_versions
  end

  private 

  def set_project_or_fail
    project_id = params[:project_id] || params[:id]
    @project = Project.by_vanity_url_or_id(project_id).take
    raise ParamRecordNotFound unless @project
  end

  def set_best_project_security_set
    @best_project_security_set = @project.best_project_security_set
  end

  def set_releases
    @releases = @best_project_security_set.releases.order(released_on: :asc).limit(10)
  end

  def set_vulnerabilities
    @vulnerabilities = Array.new(3) { [] }
    @releases.each do |r|
      @vulnerabilities[0] << r.vulnerabilities.low.count
      @vulnerabilities[1] << r.vulnerabilities.medium.count
      @vulnerabilities[2] << r.vulnerabilities.high.count
    end
  end
end

As you can see, the release_versions variable is being passed to gon and I can view it in the logs that the values that I am looking for are there.

正如您所看到的,release_versions变量正在传递给gon,我可以在日志中查看我正在寻找的值。

Once we leave the controller, the js.erb file is rendered:

离开控制器后,将呈现js.erb文件:

vulnerabilites_per_version.js.erb

alert(gon.watch.release_versions)

$(function () {
    $('#vulnerabilities').highcharts({
        chart: {
            type: 'column'
        },
        title: {
            text: 'Vulnerabilities per Version',
            align: 'left',
            style: {
                color: '#336699',
                fontSize: 16
            }
        },
        legend: {
            align:  'left',
          itemWidth: 127
        },
        xAxis: {
            categories: gon.release_versions
        },
        yAxis: {
            min: 0,
            title: {
                text: 'Vulnerabilities'
            },

            .........code.....

What could be the cause of this problem? Why am I unable to access the data in my js.erb file? According to the gon documentation, I should have everything set in order for the data to render yet it doesn't. As a second attempt, I also proceeded to read up on the gon.watch usage but again no luck. Any ideas? Help on the matter would greatly be appreciated.

可能是造成这个问题的原因是什么?为什么我无法访问js.erb文件中的数据?根据gon文档,我应该设置所有内容,以便数据呈现但却没有。作为第二次尝试,我也开始阅读gon.watch用法,但再次没有运气。有任何想法吗?非常感谢有关此事的帮助。

2 个解决方案

#1


0  

I'm not sure what gon is here but if you declare gon as an instance variable (@gon), that should do the trick.

我不确定gon在这里是什么,但如果你将gon声明为一个实例变量(@gon),那应该可以解决问题。

Controller

def show
  @dog = Dog.first
  cat = Cat.first
end

View: show.html.erb

@dog.name => "Sparky"
cat.name  => undefined method 'name' for nil class

#2


0  

I suspect that your js.erb file isn't updating the global gon variable.

我怀疑你的js.erb文件没有更新全局gon变量。

Try setting the global gon variable in the template:

尝试在模板中设置全局gon变量:

#vulnerabilites_per_version.js.erb
gon = #{gon}
console.log(gon.watch.release_versions)

#1


0  

I'm not sure what gon is here but if you declare gon as an instance variable (@gon), that should do the trick.

我不确定gon在这里是什么,但如果你将gon声明为一个实例变量(@gon),那应该可以解决问题。

Controller

def show
  @dog = Dog.first
  cat = Cat.first
end

View: show.html.erb

@dog.name => "Sparky"
cat.name  => undefined method 'name' for nil class

#2


0  

I suspect that your js.erb file isn't updating the global gon variable.

我怀疑你的js.erb文件没有更新全局gon变量。

Try setting the global gon variable in the template:

尝试在模板中设置全局gon变量:

#vulnerabilites_per_version.js.erb
gon = #{gon}
console.log(gon.watch.release_versions)