编程语言
首页 > 编程语言> > javascript-kickout.js-计算或可观察

javascript-kickout.js-计算或可观察

作者:互联网

我有一个应用程序,允许我们的客户访问我们的网站,获取报价,然后进行投资回报分析等.

有两个部分…“报价”部分和“投资回报”部分.

我正在使用淘汰赛来同步字段….因此,当客户进来并说他们需要10 x 10的单位时,我们给他们报价4,000美元.此值将作为成本复制到“投资回报”表.然后,我们扣除节能额度,投资税收额度等.以得出“净投资”.

只要用户以正确的方式遵循每个步骤,一切都会正常.

现在,如果用户已经对他们计划在我们的一个单元上花费的预算产生了兴趣,该怎么办?他们不知道他们是否需要10×10的广告单元,只知道他们有5,000美元的投资机会,并想看看这项投资是否能带来良好的回报.因此,该样本用户跳过了报价部分,只想输入他们的假定价格并获得一些数字.

我的视图模型是这样建立的:

self.height = ko.observable('<?php echo $height; ?>'),
self.width = ko.observable('<?php echo $width; ?>'),
/* Math simplified to remove gobbeldygook */
self.cost = ko.computed(function () {return (self.height() * self.width()) * 40;}),

如何设置“费用”,以便在提供高度和宽度时可以自动计算出“费用”,并且可以通过UI对其进行编辑和更改?

非常感谢您的帮助.

解决方法:

使用可写的可计算观察值,淘汰赛使此操作变得容易.您可以提供一个读取功能,就像用户已经拥有的那样,当用户访问它时会返回该值,而且还提供了在写入值时发生的逻辑.

根据您的设置,您似乎希望计算成本的写入部分来设置高度和宽度的适当值.

self.cost = ko.computed({
    read: function () { return (this.height() * this.width()) * 40; },
    write: function(value) { /* your logic here to set height and width */ },
    owner: self
});

full docs are here,下降约30%:

标签:knockout-js,javascript
来源: https://codeday.me/bug/20191123/2065779.html