|  | 4 年之前 | |
|---|---|---|
| .. | ||
| README.js | 4 年之前 | |
| README.md | 4 年之前 | |
| icon.png | 4 年之前 | |
Contents
\n\nCommunicating with users in a language that they understand and with\nconventions that they're used to is vital. Ext JS comes bundled with\nlocalization files for over 40 languages ranging from Indonesian to\nMacedonian, and it's dead-easy to set up.
\n\nIn the root directory of your copy of Ext JS there is a folder called\nlocale. This contains all the bundled translations of Ext JS\nframework. You can inspect the contents of each to see exactly what\nthey contain. Here's an excerpt from the Spanish localization file:
Ext.define(\"Ext.locale.es.form.field.Number\", {\n    override: \"Ext.form.field.Number\",\n    decimalSeparator: \",\",\n    decimalPrecision: 2,\n    minText: \"El valor mínimo para este campo es de {0}\",\n    maxText: \"El valor máximo para este campo es de {0}\",\n    nanText: \"{0} no es un número válido\"\n});\nYou can see that it applies an override to Ext.form.field.Number which applies the Spanish strings to error\nmessages and specifies Spanish decimal separator. Using an override\nensures that these properties will be overridden in class prototype\nright after the class itself is loaded.
\n\nThe simplest way to localize Ext JS is to just stick an additional\n<script> tag to your HTML:
<!DOCTYPE html>\n<html>\n<head>\n    <!-- Ensure we're using UTF-8 -->\n    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n    <title>Localization example</title>\n    <!-- Main Ext JS files -->\n    <link rel=\"stylesheet\" type=\"text/css\" href=\"extjs/resources/css/ext-all.css\">\n    <script type=\"text/javascript\" src=\"extjs/ext-debug.js\"></script>\n    <!-- Include the translations -->\n    <script type=\"text/javascript\" src=\"extjs/locale/ext-lang-es.js\"></script>\n\n    <script type=\"text/javascript\" src=\"app.js\"></script>\n</head>\n<body>\n\n</body>\n</html>\nSwitching between different languages can be accomplished by server\nside code that generates an appropriate <script> tag based on the\ncurrently selected locale.
And before you even ask for it - you really should refresh the entire\npage when switching locales. Ext JS does not support changing the\nlocale on the fly (like updating the texts inside already rendered\ncomponents).
\n\nWhen you write a custom component or plugin to Ext JS and want to\nshare it with a world take a moment to ensure it follows Ext JS\npractices for localization. At very minimum every text string that's\nshown to user should be defined as a property:
\n\nExt.define(\"Ext.ux.Weather, {\n    sunText: \"It's a nice sunny day\",\n    rainText: \"Bad weather, don't go out\",\n    // ...other code...\n});\nAlso watch out when you're dealing with dates - every language tends\nto have it's own way of writing them. So when your extension renders\na date, provide a config option to specify the format.
\n\nThis way users of your extension can easily override the\nlocale-specific parts.
\n\nBut even better is to build your extension so that it doesn't need any\nadditional localization at all.  Make use of the messages already\ntranslated in Ext JS itself (e.g. use Ext.MessageBox.buttonText.ok\nwhen rendering \"OK\" button).  Default to the default date format when\nrendering dates (Ext.util.Format.dateFormat).
Ext JS doesn't enforce any particular approach to localization. It's\nonly the framework itself that uses the approach outlined here. Feel\nfree to localize your app in whichever way feels best for you.
\n\nIf you're unsure you can use the same approach that Ext JS uses or you\ncould give a try to good-old GNU Gettext.
\n"});