Как я могу интернационализировать страницу GWT UIBinder сообщениями?

Я пытаюсь интернационализировать приложение UIBinder файлами свойств. Так как у нас уже есть много переводов, представленных com.google.gwt.i18n.client. Интерфейс сообщений (GWT 1.7.1), мы хотели бы снова использовать эти сообщения.

Я попробовал следующее:

<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
 xmlns:g="urn:import:com.google.gwt.user.client.ui" 
 xmlns:res="ui:with:be.credoc.iov.webapp.client.MessageConstants">

 <g:HTMLPanel>
  <div>
   <res:msg key="email">Emaileke</res:msg>:
   <g:TextBox ui:field="email" />
  </div>
 </g:HTMLPanel>
</ui:UiBinder>

Класс MessageConstants похож на это:

@DefaultLocale("nl")
public interface MessageConstants extends Messages {
 String email();
}

Однако это не работает. Как я могу сделать это?

22
задан Jan 18 February 2010 в 10:03
поделиться

2 ответа

Обновление:
проверьте ответ логана ниже, чтобы узнать о решении, доступном в последних версиях GWT.


У меня была (фактически была) та же проблема, что и у вас - после перехода на GWT 2.0 у меня был файл свойств, который я хотел использовать в своих файлах UiBinder. К сожалению, мне не удалось заставить его работать так, как я хотел - похоже, разработчики GWT хотят, чтобы люди использовали синтаксис, описанный в руководстве i18n для UiBinder - где интерфейс сообщений создается во время компиляции для каждого Шаблон UiBinder и т. Д.

В любом случае, вы все еще можете использовать внешние интерфейсы Сообщения , например:

<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
    xmlns:g="urn:import:com.google.gwt.user.client.ui">
    <ui:with field='cc' type='path.to.i18n.SomeMessages'/>
    <ui:with field='res' type='path.to.resource.ResourceBundle'/>
    <ui:style>
        .required {
      color: red;
      font-weight: bold;
    }
    .right {
      text-align: right;    
    }
    .textBox {
      margin-right: 7px;
    }
    </ui:style>
    <g:HTMLPanel styleName='{res.style.form} {res.style.mbox}' ui:field='mainPanel'>
        <h2 ui:field='loginHeader' />
      <h3 ui:field='loginLabel' />
      <div class='{style.textBox}'><g:TextBox ui:field="loginBox" /></div>
      <h3 ui:field='passwordLabel' />
    <div class='{style.textBox}'><g:PasswordTextBox ui:field="passwordBox" /></div>
    <div><g:CheckBox ui:field='rememberMeCheckBox' text='{cc.rememberMeCheckboxText}' /></div>
    <div class='{style.right}'><g:Button ui:field='submitButton' text='{cc.loginSubmitButtonText}' /></div>
    </g:HTMLPanel>
</ui:UiBinder> 

Хотя это работает только для таких вещей, как заголовок Button и т. Д., не содержимое разделов: / Вы можете заполнить их в классе за шаблоном UiBinder, но должен быть способ получше.

Я надеялся, что вы сможете установить внутренний HTML-код с помощью innerHTML (поскольку UiBinder должен распознавать этот метод и позволять устанавливать его значение с помощью шаблона XML / UiBinder), но, увы, в прошлый раз, когда я это проверял, этого не произошло. t work: /

13
ответ дан 29 November 2019 в 04:17
поделиться

Существует известная проблема с UiBinder в сочетании с интернационализацией, см. Также эту недавнюю ветку в багтрекере gwt: http: // code. google.com/p/google-web-toolkit/issues/detail?id=4355.

В комментарии 4 дано решение:

Если ваш файл UiBinder называется, скажем, 'LoginView.ui.xml', затем вызовите свойства файл LoginViewLoginViewUiBinderImplGenMessages.properties (да, 'LoginView' появляется дважды) и поместите его рядом с файлом java представления в исходном пакете, так что всего у вас будет 3 файла:

 LoginView.ui.xml 
LoginView.java 
LoginViewLoginViewUiBinderImplGenMessages.properties 
 
8
ответ дан 29 November 2019 в 04:17
поделиться
Другие вопросы по тегам:

Похожие вопросы: