【问题标题】:Correctly pass a Groovy list to Javascript code in GSP正确地将 Groovy 列表传递给 GSP 中的 Javascript 代码
【发布时间】:2011-01-05 00:20:30
【问题描述】:

我正在使用 Grails 制作一个 Web 应用程序。我有一个列表,其中包含必须包含在 JavaScript 中的数据,以便对 <select> 下拉列表执行一些动态加载。基本上,我从服务器获得了一个两级列表,然后第一级显示在一个下拉框上。当用户选择一个选项时,与该选项关联的列表会显示在另一个下拉框上。

gsp 页面上 JavaScript 函数的(简化)代码如下

function selecTipe() {
        var types = ${typeList}
        alert('List of types ' + types )

问题是,如果 typeList 被定义(在 Groovy 中)为

typeList = [['TYPE1', ['VAR1','VAR2','VAR3']], 
            ['TYPE2', ['VAR1','VAR2','VAR3']]
            ['TYPE3', ['VAR1','VAR2','VAR3']] ]

当页面被渲染时,JavaScript 代码看起来像

function selecTipe() {
        var types = [[ TYPE1, [ VAR1, VAR2, VAR3 ]], 
                     [ TYPE2, [ VAR1, VAR2, VAR3 ]]
                     [ TYPE3, [ VAR1, VAR2, VAR3 ]] ]
        alert('List of types ' + types )

这是错误的,因为 JavaScript 不将其视为字符串,而是将其视为引用,因为缺少引号。

有什么方法可以强制 Groovy 打印带有引号的数组列表或任何其他简单的方法来实现这一点?

PD:我可以制作一个特定的功能来实现它,但我认为这应该是一种简单的方法......

编辑:我已经添加了完整的数据结构,它比简单的列表要复杂一些

【问题讨论】:

    标签: javascript grails groovy gsp


    【解决方案1】:

    在你的 grails 控制器的操作中试试这个:

    def types = ['TYPE1', 'TYPE2', 'TYPE3'] as grails.converters.JSON
    [typeList : types]
    

    【讨论】:

      【解决方案2】:

      在你的 grails 控制器的操作中试试这个:

      def types = ['TYPE1', 'TYPE2', 'TYPE3'] as grails.converters.JSON
      [typeList : types]
      

      如果有人有对象,这将在您的 gsp 中起作用:

      <g:javascript>
          var types = JSON.parse('${typeList}');
          alert("Type id:" + types[1].id);
      </g:javascript>
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2020-01-11
        • 2017-01-24
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2014-12-13
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多