DisplayStag Сортировка и Ссылки на Pagination (URL) сгенерированы слишком длинные

StackOverflow https://stackoverflow.com/questions/3094603

  •  29-09-2019
  •  | 
  •  

Вопрос

При использовании DisplayTag URL-адрес генерируется для подкачки и сортировки слишком длинный для IE.

Есть ли путь вокруг этого, не прибегая к наружным пейджем и сортировке?

Ваше здоровье.

Это было полезно?

Решение

Надеюсь, это поможет кому-то. И если есть другой путь, то дайте мне знать.

То, как я охватил это, исключая все параметры на тег таблицы дисплея.

<display:table excludedParams="*"> ... </display:table>

Это означает, что URL не заполняется параметрами.

Отлично, но как вы держите ручку в списке объектов, которые мы используем?

Я сделал это, установив атрибут в запросе контекста. И, как я использую Plasses Framework, я сделал это с помощью ActionBeanContext.

public class SchemeActionBeanContext extends ActionBeanContext {
    public void setThings(List<Things> things) {    
        getRequest().getSession().setAttribute("stuff", things);
    }

    public List<Things> getThings() {
        return (List<Things>)getRequest().getSession().getAttribute("stuff");
    }

И тогда вы можете установить и получить их в течение всего жизненного цикла, если страница / запрос.

Другие советы

Я сталкивался с подобной проблемой, где URL со всеми полями формы прилагаются к URL-адреса во время пагинации и сортировки. Это было разрешено, идентифицируя все ссылки на пагинга, упомянутые ниже либо уникальным названием, который он образует (перейти на страницу) и внутренние HTMLS, такие как «следующий» «Prev» ITC.

Пармы JavaScript в методе ниже объясняются здесь 1) Head1 / Head2 - пройденные имена столбцов сортировки. 2) Formname - имя формы, 3) Mastername - метод, называемый в вашем контроллере

У меня есть логика на поле ввода с именем «strnamesearch» на основе которого меняются мой метод вызова.

Также запишите, как только вы сделаете это, не забудьте добавить ExcludedHedParams = "*" на дисплее: тег таблицы

Вот код:

function findAnchorGen(head1,head2,formName,masterName) {
    var formObj = eval("document."+formName);
    var methodName;
    var strSearch = trim(formObj.strNamesearch.value);
    if(strSearch == null || strSearch == '') {
        methodNameP = "fetch"+masterName;
    } else {
        methodNameP = "search"+masterName;
    }
    var anchors = document.links; // your anchor collection   
    var i = anchors.length; 
    while (i--) {
        var a = anchors[i];     
        var aRef = a.href;
        var aTitle = a.title;
        index = aTitle.indexOf("Go to page");
        var inHtml = a.innerHTML;

        if(index >= 0 || inHtml == 'Last' || inHtml == 'Next' || inHtml == 'First' || inHtml == 'Prev' || inHtml == head1 || inHtml == head2) {
            //alert("Ref = " + aRef + " | title = " + aTitle + " | inner html = " + a.innerHTML);
            a.href="#";
            a.onclick = (function(aRef,formName,methodNameP){return function(){fSubmit(aRef,formName,methodNameP);}})(aRef,formName,methodNameP);
        }
    } 
}

function fSubmitGen(aRef,formName,methodNameP) {
    var formObj = eval("document."+formName);
    formObj.action = aRef;
    formObj.method.value = methodNameP;
    formObj.submit();
}

Это обходной путь и хорошо работает для нас. Я надеюсь, что это тоже работает для вас.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top