- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用的表单不会提交,尝试时我在控制台中不断收到“未捕获的类型错误:非法调用”。
非常感谢任何帮助,我不确定我是否不小心使用了导致问题的系统/保留字。
<script>
$(document).ready(function($) {
$("#submit_btn").click(function() {
//get input field values
var user_name = $('input[name=name]').val();
var user_email = $('input[name=email]').val();
var user_add1 = $('input[name=add1]').val();
var user_add2 = $('input[name=add2]').val();
var user_town = $('input[name=town]').val();
var user_country = $('input[name=country]').val();
var user_postcode = $('input[name=postcode]').val();
var user_tel = $('input[name=tel]').val();
var user_entries = $('input[name=entries]').val();
var user_freeentries = $('input[name=freeentries]').val();
var user_entries = $('input[name=entries]').val();
var user_total = $('input[name=total]').val();
var user_question = $('select[name=question]').val();
//simple validation at client's end
//we simply change border color to red if empty field using .css()
var proceed = true;
if(user_name==""){
$('input[name=name]').css('border-color','red');
proceed = false;
}
//everything looks good! proceed...
if(proceed)
{
//data to be sent to server
post_data = {'userName':user_name, 'userEmail':user_email, 'AddressLine1':user_add1, 'AddressLine2':user_add2, 'town':user_town, 'country':user_country, 'postcode':user_add1, 'tel':user_tel, 'entries':user_entries, 'freeentries':user_freeentries, 'total':total, 'question':user_question};
//Ajax post data to server
$.post('enter.php', post_data, function(response){
//load json data from server and output message
if(response.type == 'error')
{
output = '<div class="error">'+response.text+'</div>';
}else{
output = '<div class="success">'+response.text+'</div>';
//reset values in all input fields
$('#contact_form input').val('');
$('#contact_form select').val('');
}
$("#result").hide().html(output).slideDown();
}, 'json');
}
});
//reset previously set border colors and hide all message on .keyup()
$("#contact_form input, #contact_form select").keyup(function() {
$("#contact_form input, #contact_form select").css('border-color','');
$("#result").slideUp();
});
});(jQuery);
</script>
以下是引用表格。正在测试它,没有奇怪的字符,只有纯文本。
<fieldset id="contact_form">
<div id="result"></div>
<input type="text" name="name" id="name" placeholder="Name" />
<input type="email" name="email" id="email" placeholder="Email" />
<input type="text" name="add1" id="add1" placeholder="Address Line 1" />
<input type="text" name="add2" id="add2" placeholder="Address Line 2" />
<input type="text" name="town" id="town" placeholder="Town" />
<input type="text" name="country" id="country" placeholder="Country" />
<input type="text" name="postcode" id="postcode" placeholder="Post Code" />
<input type="text" name="tel" id="tel" placeholder="Telephone number" />
<input onblur="findTotal()" type="text" name="entries" id="entries" placeholder="Number" />
<input type="text" name="freeentries" id="freeentries" placeholder="Number" />
<input type="text" name="total" id="total" placeholder="Cost of Entry" />
<select style="color:#666" name="question">
<option value="">Please Choose...</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<br><Br><br><br><br>
<label><span> </span>
<button class="submit_btn animate swing" data-delay="500" id="submit_btn">Enter</button>
</label>
</fieldset>
<script type="text/javascript">
function findTotal(){
var arr = document.getElementsByName('entries');
var tot=0;
for(var i=0;i<arr.length;i++){
if(parseInt(arr[i].value))
tot += parseInt(arr[i].value);
}
document.getElementById('total').value = "£" + tot * 50;
}
</script>
最佳答案
function findTotal(){
var arr = document.getElementsByName('entries');
var tot=0;
for(var i=0;i<arr.length;i++){
if(parseInt(arr[i].value))
tot += parseInt(arr[i].value);
}
document.getElementById('total').value = "£" + tot * 50;
}
$(document).ready(function() {
$("#submit_btn").click(function() {
//get input field values
var user_name = $('input[name=name]').val();
var user_email = $('input[name=email]').val();
var user_add1 = $('input[name=add1]').val();
var user_add2 = $('input[name=add2]').val();
var user_town = $('input[name=town]').val();
var user_country = $('input[name=country]').val();
var user_postcode = $('input[name=postcode]').val();
var user_tel = $('input[name=tel]').val();
var user_freeentries = $('input[name=freeentries]').val();
var user_entries = $('input[name=entries]').val();
var user_total = $('input#total').val();
var user_question = $('select[name=question]').val();
console.log(user_total)
//simple validation at client's end
//we simply change border color to red if empty field using .css()
var proceed = true;
if(user_name==""){
$('input[name=name]').css('border-color','red');
proceed = false;
}
//everything looks good! proceed...
if(proceed)
{
//data to be sent to server
post_data = {'userName':user_name, 'userEmail':user_email, 'AddressLine1':user_add1, 'AddressLine2':user_add2, 'town':user_town, 'country':user_country, 'postcode':user_add1, 'tel':user_tel, 'entries':user_entries, 'freeentries':user_freeentries, 'total':user_total, 'question':user_question};
console.log(post_data)
//Ajax post data to server
$.post('enter.php', post_data, function(response){
//load json data from server and output message
if(response.type == 'error')
{
output = '<div class="error">'+response.text+'</div>';
}else{
output = '<div class="success">'+response.text+'</div>';
//reset values in all input fields
$('#contact_form input').val('');
$('#contact_form select').val('');
}
$("#result").hide().html(output).slideDown();
}, 'json');
}
});
//reset previously set border colors and hide all message on .keyup()
$("#contact_form input, #contact_form select").keyup(function() {
$("#contact_form input, #contact_form select").css('border-color','');
$("#result").slideUp();
});
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
Here is the form for reference. it is being tested with no strange characters just plain text.
<fieldset id="contact_form">
<div id="result"></div>
<input type="text" name="name" id="name" placeholder="Name" />
<input type="email" name="email" id="email" placeholder="Email" />
<input type="text" name="add1" id="add1" placeholder="Address Line 1" />
<input type="text" name="add2" id="add2" placeholder="Address Line 2" />
<input type="text" name="town" id="town" placeholder="Town" />
<input type="text" name="country" id="country" placeholder="Country" />
<input type="text" name="postcode" id="postcode" placeholder="Post Code" />
<input type="text" name="tel" id="tel" placeholder="Telephone number" />
<input onblur="findTotal()" type="text" name="entries" id="entries" placeholder="Number" />
<input type="text" name="freeentries" id="freeentries" placeholder="Number" />
<input type="text" name="total" id="total" placeholder="Cost of Entry" />
<select style="color:#666" name="question">
<option value="">Please Choose...</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<br><Br><br><br><br>
<label><span> </span>
<button class="submit_btn animate swing" data-delay="500" id="submit_btn">Enter</button>
</label>
</fieldset>
$.post
请求中的 post_data
序列化存在问题。检查 post_data
对象中的所有值是否已正确序列化:这意味着您的数据必须是纯对象或字符串或数组。您还可以尝试在 ajax
设置中设置 processData: false
(您可以找到列表 here )。
编辑:再次查看html和您的代码后,发现您传递了错误的值,而不是输入“total”的值,total
而不是正确的值一个 user_total
,导致错误。正确的`post_data。请参阅更正后的代码片段。
关于javascript - 表单无法提交,未捕获类型错误 : Illegal invocation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46606839/
为什么Intellij会给出这个警告,这是什么意思,我怎样才能让它变得更好? import akka.actor.Props object Router { def props(config: C
我在两个类中使用react-native-image picker和react-native-image-crop picker库。 一个是启动库图像(react-native-image picke
晚上好, 我刚开始使用 Microsoft.Contracts(最新版本)并将其插入示例界面之上,现在它看起来像这样: namespace iRMA2.Core.Interfaces { us
我尝试制作用于 Symfony 2 上传的 ajax 脚本。Chrome 返回此错误: Uncaught TypeError: Illegal invocation jquery.min.js:4 我
我正在尝试在 java 中运行一些 javascript。我不确定脚本是否正确,我想在一段时间后终止调用。这就是我运行脚本的方式。 returnMethod = invocableEngine.inv
我正在为一个服务类编写 Spock 测试,该服务类的方法在 spring boot 应用程序中调用 Dao 类中的另一个方法。但是,我得到: Too few invocations for: 1
我们正在运行一个 Create React App (CRA) Web 应用程序,我们已向其中添加了 Google Analytics v4。我们使用 ga-4-react 启动分析npm 包。 in
我想将多个图像对象发布到 testphp.php。但控制台打印错误说非法调用。 我已经尝试过: submit $("#sub").click(function(){ // get th
当文本框为空时尝试禁用按钮时,我在 google chrome 控制台中收到此错误: function isEmpty() { var r = document.getElementById;
这是 html 这是脚本 $('#submit').click(function() { var files = $("[type='file']")[0].fil
我尝试通过ajax提交表单,下面是表单。 Date Upload File
我想弄乱 Speech Recognition API,所以我从简单的页面开始,该页面在单击 body 元素时开始识别。我的 scripts.js 文件是: var recognition = new
我在 Google 上进行了搜索,也浏览了 Stack 上提供的一系列类似问题,但不幸的是没有一个能帮助我解决问题。 下面是我正在做的事情,我从主视图调用 PartialView,但我的 Partia
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
为简单起见,我们来看一个非常简单的类: public class TestingClass { public void method1(){ System.out.printl
编辑:到目前为止建议的答案都不起作用。 我正在使用 django 运行此调用。第一次运行时,服务器返回“n_usr”(这会更改用户文件的形式)。第二次,它只是抛出一个非法调用错误。 function
每当我必须使用 gcloud 部署新的 python 函数时sdk 我收到这条消息 Allow unauthenticated invocations of new function [functio
这个问题已经有答案了: getUserMedia() in JavaScript normalizes across browsers. Illegal Invocation (1 个回答) 已关闭
我试图通过发布一些 xml 来登录来测试登录 Web 服务,但它再次出现此错误: 未捕获的类型错误:非法调用 这是代码: $(document).ready(function() { var da
function submit() { console.log('Submit!'); } function foo(callback, param) { console.log(ca
我是一名优秀的程序员,十分优秀!