2011-06-23 54 views
9

這是我的whole source code極簡主義Devise + OmniAuth應用程序。Rails3:設計國際化不本地化「密碼確認」和其他

如您所見,日本devise.ja.ymlconfig/locales

問題:當我親臨現場與郎= JA,某些字符串不是日本人,但英語:

devise i18n password confirmation

「サインアップ」 顯示正常,但 「確認密碼」 和其他人仍然用英語。其實,我grep'd我的整個項目和我的整個.rvm目錄:沒有文件包含「密碼確認」!真是莫名其妙。

這些字符串從哪裏來?他們怎麼不在devise.ja.yml中?是OmniAuth嗎?

回答

14

實際上,它們來自默認的語言yml文件。設計語言環境文件只需提供警報消息和一些通知的語言環境。他們不提供表單屬性的屬性轉換。

你可能想參觀

https://github.com/svenfuchs/rails-i18n/tree/f8606e62def45279f3498549f97699049135bd11/rails/locale

,並下載適當的(日本在您的案件)的語言文件,並把它放在./config/locales/文件夾

然後在你的Rails應用程序的配置文件(./ config/application.rb)更改區域設置以使用日語區域設置文件。

config.i18n.default_locale = :ja 

更改設置後,如果您希望任何屬性具有日文名稱,請添加如下所示的規則。

activerecord: 
    attributes: 
     user: 
      email: "Email address in Japanese" 
      password: "Password in Japanese" 
      password_confirmation: "Password confirmation in Japanese" 
+0

添加此activerecord段落確實允許我重寫這些字符串。但是我真的需要自己找到並翻譯所有這些字符串嗎?如果他們是ActiveRecord項目的一部分,是不是已經被翻譯成日文了? –

+0

我想你已經意識到了這一點,但只是爲了讓其他讀者清楚:這些字符串(例如password_confirmation)不包含在svenfuchs/rails-i18n本地化文件中。 –

+0

那麼,你永遠不會知道人們將使用什麼屬性名稱,所以本地化yml文件不能包含所有可能的翻譯。一些用戶可能使用'password',或'password_confirmation'或'phone'或'dateofbirth'或一些隨機的屬性名稱。對我而言,我確信在本地化文件中添加一行翻譯將會影響我的查看頁面中的所有屬性... – user482594