我通過編寫自定義綁定來包裝autoNumeric.js進行格式化,從而做了這樣的事情。格式化,看你能做些什麼ewith設置
<input data-bind="autoNumeric:amount, settings:{aSign:'$'}" />
退房autoNumeric.js廣泛的選擇:(gist)
ko.bindingHandlers.autoNumeric = function ($) {
function getElementValue(el) {
return parseFloat(el.autoNumericGet(), 10);
}
function getModelValue(accessor) {
return parseFloat(ko.utils.unwrapObservable(accessor()), 10);
}
return {
init: function (el, valueAccessor, bindingsAccessor, viewModel) {
var $el = $(el),
bindings = bindingsAccessor(),
settings = bindings.settings,
value = valueAccessor();
function updateModelValue() {
value(getElementValue($el));
};
$el.autoNumeric(settings);
$el.autoNumericSet(getModelValue(value), settings);
$el.change(updateModelValue);
},
update: function (el, valueAccessor, bindingsAccessor, viewModel) {
var $el = $(el),
newValue = getModelValue(valueAccessor()),
elementValue = getElementValue($el),
valueHasChanged = (newValue != elementValue);
if ((newValue === 0) && (elementValue !== 0) && (elementValue !== "0")) {
valueHasChanged = true;
}
if (valueHasChanged) {
$el.autoNumericSet(newValue);
setTimeout(function() { $el.change() }, 0);
}
}
};
}
數據使用這個自定義autoNumeric結合看起來像這樣綁定。
你有一個樣本?如有必要,我們可以編寫一個快速的自定義綁定來使用jquery.globalization API調用。 –
@RP尼邁耶夢幻般的幫助!我可能會開始使用它,知道你在附近:) – balexandre