2

我在一些应该非常简单的事情上玩得很开心。我正在使用 Struts2 Jquery 插件,<sj:select>我的页面上有一个。它设置为multiple。我有一组要预先选择的值,但没有设置任何内容。如果我在值标签中给它一个项目,则选择该项目。如果我将ArrayListofIntegers或 a Collectionof Integer(仍然是 的实例ArrayList)或逗号分隔的字符串(“100,101,102”)传递给该值,则不会选择任何内容。我尝试传递一个简单的整数数组 ( Integer[]),它至少会选择数组中的第一项,但仅此而已。所有其他人显然都被丢弃了。我无法理解我做错了什么,或者我能做些什么来完成这项工作。

<sj:select 
    href="%{myStrutsJSONAction}"
    id="itemSelect"
    formIds="editForm"
    reloadTopics="reloadItem"
    name="selectedString"
    list="availableItems"
    listKey="id"
    listValue="description"
    multiple="true"
    cssClass="form-control"
    value="selectedIds"
    />

这最初是一个常规的 Struts2 select ( ),并且在将of传递给 value 标记的情况下<s:select>工作得非常好。我已更改为 Jquery 插件版本,因为我需要根据单独列表的值重新加载数据。ArrayListIntegers

工作正常,reloadTopics正在重新填充数据,当表单提交时,我的所有选择都正确传递回服务器。但是页面加载时最初没有选择任何内容。

4

3 回答 3

1

查看插件的源代码,似乎现在不支持一次预先选择多个值。

您可以在此插件的 GitHub 存储库中注册一个新问题。

至于解决方法,您可能可以使用一些额外的 JavaScript 代码来实现。

于 2016-03-09T10:30:54.497 回答
1

问题的正确答案。我只是发布解决方法,以防有人遇到同样的问题。

最快和最简单的解决方案是将您的值放入逗号分隔的字符串中,该字符串将发送到页面。

public String strutsActionToLoadPage() {
    List<Integer> selectedItemIds = new ArrayList<Integer>();
    /*
     * Prepare your data for the page
     */

    /*
     * Set up the comma-delimited string
     */
    this.selectedItemString = "";
    for (int y = 0; y < (selectedItemIds.size()-1); y++) {
        this.selectedItemString += selectedItemIds.get(y) + ",";
    }
    if (!selectedItemIds.isEmpty()) {
        this.selectedItemString += selectedItemIds.get(selectedItemIds.size()-1);
    }
    return SUCCESS;
}

public String getSelectedItemString() {
    return this.selectedItemString;
}
public void setSeletedItemString(String selectedItemString) {
    this.selectedItemString = selectedItemString;
}

然后,使用 javascript,将字符串转换为数组,并在文档准备好时设置val()元素<sj:select>的。

$(document).ready(function() {
     var data = '<s:property value="selectedItemString" />';

     //Make an array, splitting on the commas
     var dataArray = data.split(",");

     // Set the value
     $("#itemSelect").val(dataArray);
});

这个问题帮助我解决了这个问题。

不太理想,但功能齐全。

于 2016-03-09T21:54:48.943 回答
0

在jsp中使用jquery拆分字符串变量

$(document).ready(function() {

  var subAns = $("#submitedAnswer").val();

  var toSplit = subAns.split(",");
     for (var i = 0; i < toSplit.length; i++) {
      console.log(toSplit[i]);
     ..........
     ..........
  }
});
于 2016-09-26T06:37:58.180 回答