ng-后台之国际化

本文展示了一个使用Angular实现的动态表单组件,通过Delon框架和ng-zorro-antd库支持多语言切换。示例中包含了如何在表单元素上应用国际化标签,以及通过服务和刷新schema两种方式改变语言环境。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述`import { Component, Inject, ViewChild } from ‘@angular/core’;
import { SFSchema, SFComponent } from ‘@delon/form’;
import { NzMessageService } from ‘ng-zorro-antd’;
import { ALAIN_I18N_TOKEN } from ‘@delon/theme’;
import { I18NService } from ‘@core/i18n/service’;

@Component({
selector: ‘form-i18n-simple’,
template: <button nz-button type="button" (click)="changeLang('srv')">Change Language Via Service</button> <button nz-button type="button" (click)="changeLang('ref')">Change Language Via call refresh schema</button> <sf #sf [schema]="schema" (formSubmit)="submit($event)"></sf>,
})
export class FormI18nSimpleComponent {
@ViewChild(‘sf’, { static: true }) comp: SFComponent;
schema = this.i18nSchema;

private get i18nSchema(): SFSchema {
return {
properties: {
name: {
type: ‘string’,
ui: {
i18n: ‘sf.name’,
descriptionI18n: ‘sf.description’,
optionalHelp: {
i18n: ‘sf.description’,
},
},
},
password: {
type: ‘string’,
title: this.i18n.fanyi(‘sf.name’),
description: this.i18n.fanyi(‘sf.description’),
ui: {
type: ‘password’,
},
},
},
required: [‘name’, ‘password’],
};
}

constructor(public msg: NzMessageService, @Inject(ALAIN_I18N_TOKEN) private i18n: I18NService) {}

changeLang(type: ‘srv’ | ‘ref’) {
this.i18n.use(this.i18n.zone === ‘zh’ ? ‘en-US’ : ‘zh-CN’);
if (type === ‘ref’) {
this.comp.refreshSchema(this.i18nSchema);
}
}

submit(value: any) {
this.msg.success(JSON.stringify(value));
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值