Javascript var 不会改变
Javascript var not changing
我想修改这个在提交前进行一些检查的 vtiger 函数。
我添加了globalvar
,我想用它来检查是否可以提交表单。我可以在此处更改哪些内容以获得所需的结果?
Globalvar 在函数结束时应该是 2 或 3,但它保持 1,我还在设置它的地方添加了警报以确保它到达这些点。
registerRecordPreSaveEvent : function(form) {
var thisInstance = this;
if(typeof form == 'undefined') {
form = this.getForm();
}
form.on(Vtiger_Edit_Js.recordPreSave, function(e, data) {
var accountName = thisInstance.getAccountName(form);
var recordId = thisInstance.getRecordId(form);
globalvar = 1;
var params = {};
if(!(accountName in thisInstance.duplicateCheckCache)) {
Vtiger_Helper_Js.checkDuplicateName({
'accountName' : accountName,
'recordId' : recordId,
'moduleName' : 'Accounts'
}).then(
function(data){
thisInstance.duplicateCheckCache[accountName+'_accounts'] = data['success'];
globalvar =2;
},
function(data, err){
thisInstance.duplicateCheckCache[accountName+'_accounts'] = data['success'];
thisInstance.duplicateCheckCache['message'] = data['message'];
var message = 'Company already exists';
Vtiger_Helper_Js.showMessage({'text' : message,'type': 'error'})
}
);
}
else {
if(thisInstance.duplicateCheckCache[accountName+'_accounts'] == true){
var message = 'Company already exists';
Vtiger_Helper_Js.showMessage({'text' : message,'type': 'error'})
} else {
delete thisInstance.duplicateCheckCache[accountName+'_accounts'];
return true;
}
}
if(!(accountName in thisInstance.duplicateCheckCache)) {
Vtiger_Helper_Js.checkDuplicateName({
'accountName' : accountName,
'recordId' : recordId,
'moduleName' : 'Leads'
}).then(
function(data){
globalvar =3;
console.log(globalvar);
thisInstance.duplicateCheckCache[accountName+'_leads'] = data['success'];
},
function(data, err){
thisInstance.duplicateCheckCache[accountName+'_leads'] = data['success'];
thisInstance.duplicateCheckCache['message'] = data['message'];
var message = 'Lead already exists';
Vtiger_Helper_Js.showMessage({'text' : message,'type': 'error'})
}
);
}
else {
if(thisInstance.duplicateCheckCache[accountName+'_leads'] == true){
var message = 'Lead already exists';
Vtiger_Helper_Js.showMessage({'text' : message,'type': 'error'})
} else {
delete thisInstance.duplicateCheckCache[accountName+'_leads'];
return true;
}
}
console.log(globalvar);
e.preventDefault();
})
}
此代码中有许多异步操作。 异步操作在包含函数实际返回后的某个时间完成。 因此,不能在包含函数完成后立即使用异步操作的结果,因为异步操作本身仍在进行且尚未完成。
因此,在异步操作中设置globalVar
(您正在执行的操作)在包含函数完成后不会显示其值。
结果的唯一方法是在表示异步操作已完成的回调中使用它,或者从该回调调用函数并向其传递所需的数据。 这些是你的选择。 你根本无法按照你试图的方式去做。
与这里的所有问题一样,如果您描述您尝试解决的实际问题,而不是用您尝试的解决方案来解释问题,我们可能会在更高的层面上提供帮助。
在StackOverflow上,未能描述你真正想要完成的事情被称为XY问题。
您无法在异步响应中运行e.preventDefault()
,因为当异步响应完成时,表单已提交。
您可能必须翻转逻辑,以便在所有异步操作完成且没有错误之前不会提交表单。 然后,您将手动提交表单。
相关文章:
- 控制台返回var不是't定义,但它是
- 动态地改变“”的URL;添加新项目”;链接使用javascript/jquery
- 从var向代码隐藏函数传递值
- 如何通过引用var Using DataTables来进行分页或排序
- jQuery语法添加了var
- 如何将具有文本类型值的var放入jQuery函数中
- JS:检查URL中的参数,然后迭代一个参数为var的函数
- 当var==0时,我如何显示一个警报
- jQuery:当屏幕大小改变时,如何更改默认图像和悬停图像
- javascript中对象构造函数中的var属性与this.properties
- 函数中this和var之间的区别
- JavaScript-的含义:var DndUpload=函数(inputElem){};
- Javascript var 不会改变
- 声明一个没有'var'让它成为一个全局变量或者只是改变它的值
- 改变“;var”;在创建新实例的构造函数闭包内部
- 我如何改变var map = L.mapbox.map点击(mapbox.js)
- JavaScript中带有for的数组不会改变每个var
- 如何使用Javascript替换来改变var,这是一个数字
- Angular View{{var}}正在更新,但$scope.var没有'不要改变
- 改变定时器从var = 1200显示mm:ss的标题