我有一个与不同语言小数的数字格式相关的问题。对于货币控制,系统根据来自URL参数的语言采用正确的格式;我们和de ?sap-ui-language=DE
或?sap-ui-language=US
对于具有type=Number
属性的输入字段,无论语言设置如何,始终将DOT用作小数分离器。有解决这个问题的解决方案吗?我有一个动态的sap.ui.table填充(对于行和列(,有些行具有数字字段,一些行作为文本字段,因此我在下面动态地从后端发送数据format;
temp = new sap.m.Input(sColumnId + index,{ value:"{path: '" + sColumnId + "'}" , type:"{DATATYPE}", textAlign:"Right", liveChange:[handle_livechange,this], change:[handle_change, this] , editable:"{path:'EDITABLE', type:'sap.ui.model.odata.type.String'}" }
由于某些行是基于文本的,因此我不能如下硬编码格式化;
type:'sap.ui.model.type.Float', formatOptions : { groupingEnabled: true, groupingSeparator: '.', decimalSeparator : ',', minFractionDigits: 2}}"
我尝试了自定义格式化器,但是在动态表上以某种方式找不到我的格式化功能。我尝试了动态格式的Onchange方法,但是在这种情况下,我的JavaScript计算不起作用。
如果我可以基于表达式绑定的行值控制格式选项,它也将解决我的问题,但下面的代码不起作用。
temp = new sap.m.Input(sColumnId + index,{ value:"{path: '" + sColumnId + ", =${DATATYPE} === 'Number' ? type:'sap.ui.model.type.Float', formatOptions : { groupingEnabled: true, groupingSeparator: '.', decimalSeparator : ',', minFractionDigits: 2} : type:'sap.ui.model.type.String' }"
这种方法对我有用:根据语言环境定义格式,例如在格式化文件中:
sap.ui.define([
"sap/ui/core/format/NumberFormat"
], function (NumberFormat) {
var oFloatNumberFormat = NumberFormat.getFloatInstance({
maxFractionDigits: 2,
minFractionDigits : 2,
groupingEnabled: true
} , sap.ui.getCore().getConfiguration().getLocale());
}
return {
floatFormat: function(value){
return oFloatNumberFormat.format(value);
},
}
});
现在您要在哪里使用它:
var MyVar= new sap.m.Input({
value: {
path: "..../amount" ,
formatter : function(amount) {
return yourdefinedname.floatFormat(amount);
}
}
});