umy-ui
Version:
一个基于 vue 的 PC 端表格UI库,解决万级数据渲染卡顿问题,过万数据点击全选卡顿,等等问题
55 lines (49 loc) • 1.45 kB
JavaScript
import defaultLang from 'umy-ui/tools/locale/lang/zh-CN';
// 如果是按需加载,设置u-table的locale
import tableLocale from 'umy-table/lib/locale'
import Vue from 'vue';
import deepmerge from 'deepmerge';
import Format from './format';
const format = Format(Vue);
let lang = defaultLang;
let merged = false;
let i18nHandler = function() {
const vuei18n = Object.getPrototypeOf(this || Vue).$t;
if (typeof vuei18n === 'function' && !!Vue.locale) {
if (!merged) {
merged = true;
Vue.locale(
Vue.config.lang,
deepmerge(lang, Vue.locale(Vue.config.lang) || {}, { clone: true })
);
}
return vuei18n.apply(this, arguments);
}
};
export const t = function(path, options) {
let value = i18nHandler.apply(this, arguments);
if (value !== null && value !== undefined) return value;
const array = path.split('.');
let current = lang;
for (let i = 0, j = array.length; i < j; i++) {
const property = array[i];
value = current[property];
if (i === j - 1) {
return format(value, options)
}
if (!value) return '';
current = value;
}
return '';
};
export const use = function(l) {
lang = l || lang;
if (l) {
// 如果是按需加载,设置u-table语言
tableLocale.use(l)
}
};
export const i18n = function(fn) {
i18nHandler = fn || i18nHandler;
};
export default { use, t, i18n };