2012-05-25 2 views
1

Здесь мое простое приложение JSF для отображения ошибки JavaScript API с помощью метода jsf.util.chain.JSF JavaScript API jsf.util.chain не работает должным образом

Использование:

  • JRE 1.6
  • Maven 3
  • JSF 2.1.8
  • Tomcat 7
  • причал 6 (для запуска из Maven причалу: запустить)
  • Mozilla Firefox 12,0
  • Firebug 1.9.2

Здесь вид:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<f:view xmlns="http://www.w3.org/1999/xhtml" xmlns:h="http://java.sun.com/jsf/html" xmlns:f="http://java.sun.com/jsf/core" 
    xmlns:ui="http://java.sun.com/jsf/facelets"> 

    <h:head> 
     <title>Test JSF 2.0 Javascript API</title> 
     <script type="text/javascript"> 
      function returnTrue(){ 
       debug('return true'); 
       return true; 
      } 
      function returnFalse(){ 
       debug('return false');  
       return false; 
      } 

      function debug(obj) {    
       if (console) { 
        if(console.debug){ 
         //for firebug 
         //http://getfirebug.com/wiki/index.php/Console_API 
         console.debug(obj); 
        } 
       } 
       else if (console) { 
        if(console.log){ 
         //for IE 
         //http://msdn.microsoft.com/en-us/library/dd565625(v=vs.85).aspx 
         console.log(obj); 
        } 
       }    
      } 

     </script> 
    </h:head> 
    <h:body> 
     <h:form> 
      <br /> 
      <br /> 
      <h1 align="center">Test jsf.util.chain</h1> 
      <br /> 
      <table align="center"> 
       <tbody> 
        <tr> 
         <td>Combo A</td> 
         <td><h:selectOneMenu id="comboa" value="#{comboTest1.combo1Value}" onchange="returnTrue()"> 
           <f:selectItems value="#{comboTest1.values1}" /> 
           <f:ajax listener="#{comboTest1.changeCombo1}" render="combob" /> 
          </h:selectOneMenu></td> 
        </tr> 
        <tr> 
         <td><label>Combo B</label></td> 
         <td><h:selectOneMenu id="combob" value="#{comboTest1.combo2Value}" title="Depend of combo 1" onchange="returnFalse()"> 
           <f:selectItems value="#{comboTest1.values2}" /> 
           <f:ajax listener="#{comboTest1.changeCombo2}" render="@this labela" /> 
          </h:selectOneMenu></td> 
        </tr> 
        <tr> 
         <td>Label A</td> 
         <td><h:outputLabel id="labela" value="#{comboTest1.labelValue}" title="Depend of combo 2" /></td> 
        </tr> 
       </tbody> 
      </table> 
      <br /> 
      <br /> 
      <br /> 
     </h:form> 
    </h:body> 
</f:view> 

Здесь управляемый компонент:

package com.ms.test.jsf.bug; 

/** 
* 
*/ 

import java.io.Serializable; 
import java.util.ArrayList; 
import java.util.Collections; 
import java.util.HashMap; 
import java.util.List; 
import java.util.Map; 
import java.util.Set; 

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ViewScoped; 
import javax.faces.event.AjaxBehaviorEvent; 
import javax.faces.model.SelectItem; 

/** 
* @author soaint 
* 
*/ 
@ManagedBean(name = "comboTest1") 
@ViewScoped 
public class ComboTest1 implements Serializable { 

    private Map<String, List<String>> combinado = null; 

    private Object combo1Value = null; 

    private Object combo2Value = null; 

    private Object labelValue = null; 

    /** 
    * 
    */ 
    private static final long serialVersionUID = -4737479400003511726L; 

    public ComboTest1() { 

     System.out.println("CREATE ComboTest1"); 

     combinado = new HashMap<String, List<String>>(); 
     List<String> list = null; 
     for (int i = 0; i < 10; i++) { 
      list = new ArrayList<String>(); 
      for (int k = 0; k < 10; k++) { 
       list.add(i + " - " + k); 
      } 
      combinado.put(i + "", list); 
     } 
    } 

    public void changeCombo1(AjaxBehaviorEvent abe) { 
     System.out.println("CHANGE MENU A === " + combo1Value); 
    } 

    public void changeCombo2(AjaxBehaviorEvent abe) { 
     System.out.println("CHANGE MENU B === " + combo2Value); 
     labelValue = combo2Value; 
    } 

    public List<SelectItem> getValues1() { 
     List<SelectItem> list = new ArrayList<SelectItem>(); 

     Set<String> keys = combinado.keySet(); 
     List<String> listi = new ArrayList<String>(keys); 
     Collections.sort(listi); 
     for (Object object : listi) { 
      list.add(new SelectItem(object, " -- " + object + " -- ")); 
     } 
     list.add(0, new SelectItem(null, " ------- ")); 

     return list; 
    } 

    public List<SelectItem> getValues2() { 
     List<SelectItem> list = new ArrayList<SelectItem>(); 

     List<? extends Object> keys = combinado.get(combo1Value); 
     if (keys != null) { 
      for (Object object : keys) { 
       list.add(new SelectItem(object, " -- " + object + " -- ")); 
      } 
     } 

     return list; 
    } 

    public Object getCombo1Value() { 
     return combo1Value; 
    } 

    public void setCombo1Value(Object combo1Value) { 
     this.combo1Value = combo1Value; 
    } 

    public Object getCombo2Value() { 
     return combo2Value; 
    } 

    public void setCombo2Value(Object combo2Value) { 
     this.combo2Value = combo2Value; 
    } 

    public Object getLabelValue() { 
     return labelValue; 
    } 

} 

Прост, вид имеет два selecOne, первый выбор есть в OnChange события вызова returnTrue и второй выбор вызов события returFalse. Оба имеют ajax-вызов управляемойрии, привязанной к изменению (по умолчанию). Внутренне JSF присоединиться к обычаю OnChange атрибутов и АЯКС mojarra вызова в jsf.util.chain вызов:

<select id="j_idt5:comboa" name="j_idt5:comboa" size="1" onchange="jsf.util.chain(this,event,'returnTrue()','mojarra.ab(this,event,\'valueChange\',0,\'j_idt5:combob\')')"> 
... 
<select id="j_idt5:combob" name="j_idt5:combob" size="1" title="Depend of combo 1" onchange="jsf.util.chain(this,event,'returnFalse()','mojarra.ab(this,event,\'valueChange\',0,\'@this j_idt5:labela\')')"> 
... 

especification из jsf.util.chain на оракул сайте http://goo.gl/GlNmj рекламы:

<static> jsf.util.chain(source, event) 

переменной длиной которая вызывает произвольное количество скриптов. Если какой-либо скрипт в цепочке возвращает false, цепочка закорочена и последующие скрипты не будут вызываться. Любое количество скриптов может указываться после аргумента события.

Это неправда, у второго выбора есть вызов selectFalse, но это огонь ajax.

Причина:

Я мой JSF настроен в режиме Deveploment в web.xml контекстно-парам и может отладить jsf.js несжатого версии. В моей версии JSF использовал jsf.util.chain объявлена ​​в строке 2247. вставляю бряк на линии 2260 на код:

var returnValue = f.call(thisArg, event); 

Полный метод:

jsf.util.chain = function(source, event) { 

    if (arguments.length < 3) { 
     return true; 
    } 

    // RELEASE_PENDING rogerk - shouldn't this be getElementById instead of null 
    var thisArg = (typeof source === 'object') ? source : null; 

    // Call back any scripts that were passed in 
    for (var i = 2; i < arguments.length; i++) { 

     var f = new Function("event", arguments[i]); 
     var returnValue = f.call(thisArg, event); 

     if (returnValue === false) { 
      return false; 
     } 
    } 
    return true; 

}; 

после первого вызова метода (returnTrue или returnFalse) returnValue всегда undefined значение.

Полный код моего теста здесь http://goo.gl/zeUL0

Скачать, разархивировать, откройте консоль, чтобы распаковать путь и запустить

mvn clean jetty:run 

Открыть веб-браузер на http://localhost:8080/testBugJSF/

Мои вопросы: ли это было действительная реализация и базовый JavaScript подверглись изменениям, которые повлияли на результаты этой реализации? Как сообщить об этом, чтобы исправить? Что такое путь отчета JSF? Как я могу исправить эту проблему непосредственно в моем приложении?

ответ

1

каждый способ должен быть возвращен.

<tr> 
        <td>Combo A</td> 
        <td><h:selectOneMenu id="comboa" value="#{comboTest1.combo1Value}" onchange="return returnTrue()"> 
          <f:selectItems value="#{comboTest1.values1}" /> 
          <f:ajax listener="#{comboTest1.changeCombo1}" render="combob" /> 
         </h:selectOneMenu></td> 
       </tr> 
Смежные вопросы