javascript - knockout 到计算列的自定义绑定(bind)

标签 javascript knockout.js

我有一个“金钱”的自定义绑定(bind)。它将在开头插入一个美元符号,并为小数点左边每 3 位添加列。此外,同一列是 ko.compulated 列。

我遇到的问题是,我必须将该列格式化为 setter :

myColumn.myValue(functionToGenerateNewValue(parameter)()); //notice the parens after the function to actually retrieve the value

为了让它能够正确地进行金钱绑定(bind)。但如果我希望计算值能够即时工作,那么必须这样设置:

myColumn.myValue = ko.computed(functionToGenerateNewValue(parameter));

以下是资金绑定(bind)的代码:

var cleanInput = function (value) {
    return parseFloat(value.replace(/[^0-9.-]/g, ''));
}

ko.bindingHandlers.money = {
    init: function (elm, valueAccessor) {
        $(elm).change(function () {
            valueAccessor()(cleanInput(elm.value));
        }).addClass('money');
    },
    update: function (elm, valueAccessor, allBindingsAccessor) {
        var value = ko.utils.unwrapObservable(valueAccessor())
        $elm = $(elm),
        method = $elm.is(":input") ? "val" : "html";
        $elm[method](formatCurrency(value));
    }
};

当它被作为计算值调用时,elm.value 是失败的部分,因为它包含一个函数而不是一个值。

知道如何将这两种实现混合在一起吗?

编辑:这是我的新版本,我仍然有点坚持......

if (goalMonth > viewModel.LastProcessedMonth()) {
                    if (goal.LYMonthSales() === goal.LYMonthSalesActual()) {

                        goal.LYMonthSales = ko.computed({
                            read: generateTotalSales(goalMonth),
                            write: function (newValue) {
                                goal.LYMonthSales(newValue);
                            }
                        });
                        goal.LYMonthSalesComputed = ko.computed({
                            read: goal.LYMonthSales,
                            write: function (newValue) {
                                goal.LYMonthSales(newValue);
                            }
                        });
                        //goal.LYMonthSales(generateTotalSales(goalMonth)());
                    }

                    goal.LYMonthSalesActual = ko.computed(generateTotalSales(goalMonth));
                    //goal.LYMonthSalesActual(generateTotalSales(goalMonth)());
                }

“LYMonthSales”过去显示在 View 上,但现在我显示“LYMonthSalesCompulated”。

现在,“写入”并不是将值写入 LYMonthSales 属性。 (调用我的save时,原来的值依然存在)

最佳答案

我想你想要一个writeblae computed observable 。这将允许您指定将新值写入计算值的逻辑。像这样的事情:

myColumn.myValue = ko.computed({
    read: functionToGenerateNewValue(parameter),
    write: function(newVal){
       //now manually provide the logic to handle a new value
    },
    owner: myColumn //optional - will cause the `this` value to be correct
});

关于javascript - knockout 到计算列的自定义绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20432429/

相关文章:

javascript - 如何保存 window.URL.createObjectURL() 结果以供将来使用?

javascript - 从 Chrome 扩展程序到 App Engine 的 POST 请求作为 GET 请求收到

javascript - 绑定(bind) html 时不会发生 knockout 表单提交

javascript - 使用 knockout.js 将 json 数据传递给 mvc 6 web 应用程序时的空值

Knockout.js 复杂对象绑定(bind)结果为空 HTML 输出

javascript - 检索 CSSStyleDeclaration 原生 Javascript 对象的键

javascript - 如何将 Blob 转换为图像(JPG 格式)

javascript - 小数点太多 + 网站上看不到样式

javascript - KnockoutJS select 在设置默认值后触发 onChange

jquery - asp mvc3,带有包含 json 数组的隐藏输入的帖子表单