{"id":548,"date":"2024-01-13T17:12:59","date_gmt":"2024-01-13T09:12:59","guid":{"rendered":"https:\/\/fugary.com\/?p=548"},"modified":"2024-01-16T19:14:59","modified_gmt":"2024-01-16T11:14:59","slug":"%e4%bb%8e%e9%9b%b6%e6%90%ad%e5%bb%ba%e5%9f%ba%e4%ba%8eelement-plus%e7%9a%84vue3%e9%a1%b9%e7%9b%ae02-%e5%9b%bd%e9%99%85%e5%8c%96%e5%a4%9a%e8%af%ad%e8%a8%80%e6%94%af%e6%8c%81","status":"publish","type":"post","link":"https:\/\/fugary.com\/?p=548","title":{"rendered":"\u4ece\u96f6\u642d\u5efa\u57fa\u4e8eelement-plus\u7684Vue3\u9879\u76ee02\u2014\u2014\u56fd\u9645\u5316\u591a\u8bed\u8a00\u652f\u6301"},"content":{"rendered":"<h3>\u591a\u8bed\u8a00\u652f\u6301<\/h3>\n<p>\u8fd9\u91cc\u8981\u652f\u6301\u591a\u8bed\u8a00\uff0c\u9700\u8981\u63a7\u4ef6\u652f\u6301\u591a\u8bed\u8a00\uff0c\u4ee5\u53ca\u81ea\u5df1\u9879\u76ee\u8981\u652f\u6301\u591a\u8bed\u8a00\uff0c\u53e6\u5916\u8981\u63d0\u4f9b\u591a\u8bed\u8a00\u7684\u5207\u6362\u529f\u80fd\u3002<\/p>\n<h4>element-plus\u591a\u8bed\u8a00<\/h4>\n<p>element plus\u7684\u56fd\u9645\u5316\u591a\u8bed\u8a00\u53c2\u8003\uff1a<a href=\"https:\/\/element-plus.gitee.io\/zh-CN\/guide\/i18n.html\">https:\/\/element-plus.gitee.io\/zh-CN\/guide\/i18n.html<\/a><\/p>\n<p>\u5f15\u5165<code>element<\/code>\u56fd\u9645\u5316\u8d44\u6e90<\/p>\n<pre><code class=\"language-js\">import ElementPlus from &#039;element-plus&#039;\nimport zhCn from &#039;element-plus\/dist\/locale\/zh-cn.mjs&#039;\n\napp.use(ElementPlus, {\n  locale: zhCn,\n})<\/code><\/pre>\n<p><code>element-plus<\/code>\u5168\u5c40\u914d\u7f6e\uff1a<a href=\"https:\/\/element-plus.gitee.io\/zh-CN\/component\/config-provider.html\">https:\/\/element-plus.gitee.io\/zh-CN\/component\/config-provider.html<\/a><\/p>\n<p>\u5207\u6362\u8bed\u8a00\u9700\u8981\u901a\u8fc7\u5168\u5c40\u914d\u7f6e\u5b9e\u73b0\u3002<\/p>\n<h4>day.js\u591a\u8bed\u8a00<\/h4>\n<p>element-plus\u4f7f\u7528\u4e86day.js\uff0c\u4e5f\u9700\u8981\u5b9a\u4e49day.js\u7684\u591a\u8bed\u8a00<\/p>\n<pre><code class=\"language-js\">import &#039;dayjs\/locale\/zh-cn&#039;\ndayjs.locale(&#039;zh-CN&#039;) \/\/ \u5168\u5c40\u4f7f\u7528\u7b80\u4f53\u4e2d\u6587\ndayjs.weekdays() \/\/  [ &quot;\u661f\u671f\u65e5&quot;, &quot;\u661f\u671f\u4e00&quot;, &quot;\u661f\u671f\u4e8c&quot;, &quot;\u661f\u671f\u4e09&quot;, &quot;\u661f\u671f\u56db&quot;, &quot;\u661f\u671f\u4e94&quot;, &quot;\u661f\u671f\u516d&quot; ]<\/code><\/pre>\n<h4>\u9879\u76ee\u591a\u8bed\u8a00<\/h4>\n<p>\u9879\u76ee\u81ea\u5df1\u7684\u56fd\u9645\u5316\u9700\u8981\u4f7f\u7528<code>vue-i18n<\/code>\uff0c\u5b9e\u9645\u4e0a\u662f<code>vue-i18n<\/code>\u7684\u65b0\u7248\u672c<code>v9.x<\/code>\uff0c\u4ee5\u524d<code>vue-i18n v8.x<\/code>\u662f<code>vue2<\/code>\u4f7f\u7528\u7684\uff0c\u8981\u6ce8\u610f\u7248\u672c\u548c\u6587\u6863\u5730\u5740\uff0c\u4ee5\u524d\u8001\u7248\u672c\u7684\u6587\u6863\u4e0d\u80fd\u7528\uff0c\u8981\u4f7f\u7528\u65b0\u7684\u6587\u6863\u5730\u5740\u3002<\/p>\n<p>\u6587\u6863\u5730\u5740\uff1a<a href=\"https:\/\/vue-i18n.intlify.dev\/\">https:\/\/vue-i18n.intlify.dev\/<\/a><\/p>\n<p>\u8001\u7248\u672c\u6587\u6863\uff08<code>Vue2<\/code>\uff09\uff1a<a href=\"https:\/\/kazupon.github.io\/vue-i18n\/zh\/\">https:\/\/kazupon.github.io\/vue-i18n\/zh\/<\/a><\/p>\n<p><code>github<\/code>\u5730\u5740\uff1a<a href=\"https:\/\/github.com\/intlify\/vue-i18n-next\">https:\/\/github.com\/intlify\/vue-i18n-next<\/a><\/p>\n<p>\u5b89\u88c5<code>vue-i18n<\/code><\/p>\n<pre><code class=\"language-sh\">npm install vue-i18n --save<\/code><\/pre>\n<p>\u81ea\u5b9a\u4e49\u8d44\u6e90\u6587\u4ef6\uff0c\u6211\u8fd9\u91cc\u4f7f\u7528<code>messages_cn.js<\/code>\u548c<code>messages_en.js<\/code>\u5206\u522b\u5b58\u653e\u4e2d\u82f1\u6587\u8d44\u6e90\u7684<code>key<\/code>\uff1a<\/p>\n<pre><code class=\"language-js\">import { createI18n } from &#039;vue-i18n&#039;\nimport messagesCn from &#039;.\/messages_cn&#039;\nimport messagesEn from &#039;.\/messages_en&#039;\n\nconst i18n = createI18n({\n  locale: &#039;zh-CN&#039;, \/\/ set locale\n  fallbackLocale: &#039;zh-CN&#039;, \/\/ set fallback locale\n  messages: {\n    &#039;zh-CN&#039;: messagesCn,\n    &#039;en-US&#039;: messagesEn\n  }\n})\napp.use(i18n)<\/code><\/pre>\n<p>\u81ea\u5b9a\u4e49\u8d44\u6e90\u6587\u4ef6\uff0c\u6211\u8fd9\u91cc\u4f7f\u7528<code>messages_cn.js<\/code>\u548c<code>messages_en.js<\/code>\u5206\u522b\u5b58\u653e\u4e2d\u82f1\u6587\u8d44\u6e90\u7684<code>key<\/code>\uff1a<\/p>\n<pre><code class=\"language-js\">\/\/ \u901a\u7528\u8d44\u6e90\nconst common = {\n  label: {\n    login: &#039;\u767b\u5f55&#039;,\n    index: &#039;\u9996\u9875&#039;\n  }\n}\nexport default {\n  common\n}\n<\/code><\/pre>\n<p>\u4f7f\u7528\u793a\u4f8b\uff1a<\/p>\n<pre><code class=\"language-html\">{{ $t(&#039;common.label.login&#039;) }}<\/code><\/pre>\n<p>\u5b9e\u9645\u8d44\u6e90\u6587\u4ef6\u5c31\u662f<code>js<\/code>\u5bf9\u8c61<\/p>\n<h4>\u8bed\u8a00\u52a8\u6001\u5207\u6362<\/h4>\n<p>\u8981\u5b9e\u73b0\u8bed\u8a00\u5207\u6362\uff0c\u9700\u8981\u4f7f\u7528\u4e0d\u540c\u7684\u65b9\u5f0f\u7ec4\u5408\uff0celement-plus\u9700\u8981\u7528ConfigProvider\u5b9e\u73b0\uff0c\u5176\u4ed6\u90fd\u6709\u81ea\u5df1\u7684\u5b9e\u73b0\u65b9\u5f0f<\/p>\n<ol>\n<li><code>element-plus<\/code>\u4fee\u6539\u8bed\u8a00\n<ol>\n<li>\u4fee\u6539configProvider\u7684locale\u503c\uff1a<code> &lt;el-config-provider :locale=&quot;elementLocale.localeData&quot;&gt;<\/code><\/li>\n<\/ol>\n<\/li>\n<li><code>day.js<\/code>\u4fee\u6539\u8bed\u8a00\n<ol>\n<li>\u8c03\u7528<code>dayjs.locale(&#039;zh-CN&#039;)<\/code><\/li>\n<\/ol>\n<\/li>\n<li>vue-i18n\u4fee\u6539\u8bed\u8a00\n<ol>\n<li>\u4fee\u6539<code> i18n.global.locale.value = &#039;zh-CN&#039;<\/code>\u7684\u503c<\/li>\n<\/ol>\n<\/li>\n<\/ol>\n<p><code>GlobalConfigStore<\/code>\u5b58\u50a8\u56fd\u9645\u5316\u4fe1\u606f<\/p>\n<p>\u53c2\u8003\u4ee3\u7801\uff1a<\/p>\n<pre><code class=\"language-js\">import { createI18n } from &#039;vue-i18n&#039;\nimport { ref } from &#039;vue&#039;\nimport messagesCn from &#039;.\/messages_cn&#039;\nimport messagesEn from &#039;.\/messages_en&#039;\nimport zhCn from &#039;element-plus\/dist\/locale\/zh-cn.mjs&#039;\nimport en from &#039;element-plus\/dist\/locale\/en.mjs&#039;\nimport &#039;dayjs\/locale\/zh-cn&#039;\nimport dayjs from &#039;dayjs&#039;\nimport { useGlobalConfigStore } from &#039;@\/stores\/GlobalConfigStore&#039;\nimport { GlobalLocales } from &#039;@\/consts\/GlobalConstants&#039;\n\nconst DEFAULT_LOCALE = &#039;zh-CN&#039;\ndayjs.locale(DEFAULT_LOCALE) \/\/ dayjs\u7684\u8bed\u8a00\u914d\u7f6e\n\nconst i18n = createI18n({\n  locale: DEFAULT_LOCALE, \/\/ set locale\n  legacy: false, \/\/ you must set `false`, to use Composition API\n  fallbackLocale: DEFAULT_LOCALE, \/\/ set fallback locale\n  messages: {\n    &#039;zh-CN&#039;: messagesCn,\n    &#039;en-US&#039;: messagesEn\n  } \/\/ set locale messages\n})\n\nexport const elementLocale = ref({ \/\/ \u7528\u4e8eelement-plus\n  localeData: zhCn\n})\n\nexport const changeMessages = locale =&gt; {\n  i18n.global.locale.value = locale\n  elementLocale.value.localeData = locale === DEFAULT_LOCALE ? zhCn : en\n  dayjs.locale(locale.toLowerCase())\n}\n\nexport const $changeLocale = locale =&gt; {\n  useGlobalConfigStore().changeLocale(locale)\n}\n<\/code><\/pre>\n<pre><code class=\"language-js\">\/\/ store\u4e2d\u5168\u5c40\u4fee\u6539locale\nconst currentLocale = ref(GlobalLocales.CN)\nchangeLocale (locale) {\n  if (Object.values(GlobalLocales).includes(locale)) {\n    currentLocale.value = locale\n  } else {\n    throw new Error(`Locale ${locale} is not supported.`)\n  }\n  changeMessages(locale)\n}<\/code><\/pre>\n<p>\u9700\u8981\u7684\u5730\u65b9\u8c03\u7528<code>globalConfigStore.changeLocale(&#039;zh-CN&#039;)<\/code>\u4e4b\u7c7b\u7684\u5b9e\u73b0\u8bed\u8a00\u5207\u6362<\/p>\n<p><code>element-plus<\/code>\u914d\u5408<code>config-provider<\/code>\u4f7f\u7528\uff1a<\/p>\n<pre><code class=\"language-html\">  &lt;el-config-provider :locale=&quot;elementLocale.localeData&quot;&gt;\n    &lt;router-view \/&gt;\n  &lt;\/el-config-provider&gt;<\/code><\/pre>\n<p>\u6700\u7ec8\u5f00\u6e90\u5730\u5740\uff1a<\/p>\n<p><a href=\"https:\/\/github.com\/fugary\/simple-element-plus-template\">https:\/\/github.com\/fugary\/simple-element-plus-template<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u591a\u8bed\u8a00\u652f\u6301 \u8fd9\u91cc\u8981\u652f\u6301\u591a\u8bed\u8a00\uff0c\u9700\u8981\u63a7\u4ef6\u652f\u6301\u591a\u8bed\u8a00\uff0c\u4ee5\u53ca\u81ea\u5df1\u9879\u76ee\u8981\u652f\u6301\u591a\u8bed\u8a00\uff0c\u53e6\u5916\u8981\u63d0\u4f9b\u591a\u8bed\u8a00\u7684\u5207\u6362\u529f\u80fd\u3002 el [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[6],"tags":[132,10,133],"_links":{"self":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/548"}],"collection":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=548"}],"version-history":[{"count":3,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/548\/revisions"}],"predecessor-version":[{"id":572,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/548\/revisions\/572"}],"wp:attachment":[{"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=548"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=548"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=548"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}