- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 HTML 表单中使用 Javascript 实现算术运算符的简单功能。但它不起作用。这似乎是正确的,但不知道为什么它没有在所需的领域显示出值(value)。请仔细阅读我的以下代码和指南。
var input = $('[name="ServiceTotalCost"],[name="GrantRequest"],[name="MatchingShare"]'),
ServiceTotalCost = $('[name="ServiceTotalCost"]'),
GrantRequest = $('[name="GrantRequest"]'),
MatchingShare = $('[name="MatchingShare"]');
input.change(function() {
var ServiceTotalCost = (isNaN(parseInt(ServiceTotalCost.val()))) ? 0 : parseInt(ServiceTotalCost.val());
var GrantRequest = (isNaN(parseInt(GrantRequest.val()))) ? 0 : parseInt(GrantRequest.val());
if (ServiceTotalCost > GrantRequest) {
Difference = ServiceTotalCost - GrantRequest;
MatchingShare.val(Difference);
} else if (GrantRequest >= ServiceTotalCost) {
PercentAge = (GrantRequest * 20) / 100;
MatchingShare.val(PercentAge);
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="col-md-12">
<div class="form-group form-float">
<h2>*Support Requried Through Grant</h2><br>
<div class="form-line">
<input type="number" class="form-control" name="ServiceTotalCost" id="ServiceTotalCost" required>
<label class="form-label">Total cost of the service (Rs.)</label>
</div>
</div>
</div>
<div class="col-md-12">
<div class="form-group form-float">
<div class="form-line">
<input type="number" class="form-control" name="GrantRequest" max="500000" id="GrantRequest" required>
<label class="form-label">Amount of grant requested (Rs.)*</label>
</div>
</div>
</div>
<div class="col-md-12">
<div class="form-group form-float">
<div class="form-line">
<input type="number" name="MatchingShare" id="MatchingShare" class="form-control" readonly>
<label class="form-label">Matching share by the applicant (Rs.)</label>
</div>
</div>
</div>
最佳答案
您将在控制台中看到以下内容:
Uncaught TypeError: Cannot read property 'val' of undefined
原因是 change
处理程序中的类似内容:
var ServiceTotalCost = (isNaN(parseInt(ServiceTotalCost.val()))) ? 0 : parseInt(ServiceTotalCost.val());
这会创建一个本地 ServiceTotalCost
变量,该变量最初的值为undefined
,然后在其初始化程序中尝试将其用作对象。 (我假设您打算从函数外部使用 ServiceTotalCost
,但本地遮蔽它,使其无法访问。)
为本地变量提供与处理程序关闭的变量不同的名称,这些变量保存字段的 jQuery 对象。
你的代码也成为我所说的The Horror of Implicit Globals的牺牲品。通过在分配之前不声明 Difference
和 PercentAge
,您将创建全局变量。相反,声明它们。
最后,JavaScript 中压倒性的约定是变量以小写字母开头,因此是 difference
而不是 Difference
等。(此外, 百分比
通常不大写)。
例如:
var input = $('[name="ServiceTotalCost"],[name="GrantRequest"],[name="MatchingShare"]'),
ServiceTotalCost = $('[name="ServiceTotalCost"]'),
GrantRequest = $('[name="GrantRequest"]'),
MatchingShare = $('[name="MatchingShare"]');
input.change(function() {
var cost = (isNaN(parseInt(ServiceTotalCost.val()))) ? 0 : parseInt(ServiceTotalCost.val());
var request = (isNaN(parseInt(GrantRequest.val()))) ? 0 : parseInt(GrantRequest.val());
if (cost > request) {
var difference = cost - request;
MatchingShare.val(difference);
} else if (request >= cost) {
var percentage = (request * 20) / 100;
MatchingShare.val(percentage);
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="col-md-12">
<div class="form-group form-float">
<h2>*Support Requried Through Grant</h2><br>
<div class="form-line">
<input type="number" class="form-control" name="ServiceTotalCost" id="ServiceTotalCost" required>
<label class="form-label">Total cost of the service (Rs.)</label>
</div>
</div>
</div>
<div class="col-md-12">
<div class="form-group form-float">
<div class="form-line">
<input type="number" class="form-control" name="GrantRequest" max="500000" id="GrantRequest" required>
<label class="form-label">Amount of grant requested (Rs.)*</label>
</div>
</div>
</div>
<div class="col-md-12">
<div class="form-group form-float">
<div class="form-line">
<input type="number" name="MatchingShare" id="MatchingShare" class="form-control" readonly>
<label class="form-label">Matching share by the applicant (Rs.)</label>
</div>
</div>
</div>
请注意,您不需要像这样的行中的条件运算符:
var cost = (isNaN(parseInt(ServiceTotalCost.val()))) ? 0 : parseInt(ServiceTotalCost.val());
由于 NaN
和 0
都是假值,因此您可以使用 ||
来获得相同的结果:
var cost = parseInt(ServiceTotalCost.val()) || 0;
我应该注意,parseInt
可能是也可能不是转换为数字的最佳选择;请参阅my answer here了解您的选择及其优缺点。
您可能根本不需要解析。在现代浏览器上,您可以从 valueAsNumber
属性获取数值。也就是说,如果您需要支持没有它的旧版浏览器,它对您没有多大帮助:
var cost = ServiceTotalCost.prop("valueAsNumber") || parseInt(ServiceTotalCost.val()) || 0;
但是,如果您不必支持不支持 type="number"
的浏览器,那么:
var cost = ServiceTotalCost.prop("valueAsNumber");
关于Javascript 函数未在所需字段中给出算术值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60111503/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!