서식 지정을 위해 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 바인딩 외모를 사용하여 바인딩 :
<input data-bind="autoNumeric:amount, settings:{aSign:'$'}" />
체크 아웃 autoNumeric.js에게 다양한 옵션을 사용자가 설정 ewith 무엇을 할 수 있는지에 서식합니다.
는 최신 autoNumeric 버전 (1.9.x)와 호환되도록 수정? 필요한 경우 jquery.globalization API 호출을 사용하는 빠른 사용자 정의 바인딩을 작성할 수 있습니다. –
@RP Niemeyer 환상적인 도움! 나는 당신이 주변에 있다는 것을 알면서 지금 그것을 사용할지도 모른다. – balexandre