今天遇到个问题,报错大概是这样:
这是一个点击事件报的错,按钮代码:
<a href="javascript:doNce(${pkIadCall.id});" οnclick="return confirmx('确认要立即执行一次么?', this.href)">立即执行</a>
js代码(获取参数并执行一个AJAX方法):
function doNce(callId){
layer.load(2);
$.ajax({
type:"POST",
url:'',
data: {callId : callId},
dataType:"json",
success:function(dataMap){
if(dataMap.result == 1){
MessagerAlert('提示', '执行失败'+dataMap.errorMsg);
}else if(dataMap.result == 0){
RepeatFindByCallId(callId);
}
},
error:function(dataMap){
MessagerAlert('提示', '失败');
}
});
}
我们看到,<a>标签里调用方法的超链接为:javascript:doNce(${pkIadCall.id});传递值:${pkIadCall.id}。看似没有问题,也不存在缺少“)”的情况,那么错误到底在哪里?
经过调试我发现,这里的function方法都没进去,也就是说,点击之后,function获取入参的时候程序就已经报错了。
其实,这里是程序对传递值的属性判定出现错误,解决方法很简单,就是给传值加上‘’号,改为:javascript:doNce('${pkIadCall.id}');就可以了。
为什么说是传值属性判定错误呢,让我们来看看测试方法:
首先,在javascript初始化的时候加上变量:
var ctx_asset = {
projectCode : '585443',
}
然后,在后台修改传入参数,将${pkIadCall.id}改为${pkIadCall.remarks},并将remarks参数值改为ctx_asset.projectCode。
现在,我们再将‘’号去掉,js代码不变:
<a href="javascript:doNce(${pkIadCall.remarks});" οnclick="return confirmx('确认要立即执行一次么?', this.href)">立即执行</a>
点击按钮,doNce(callId)方法成功接收到值callId = 585443
这说明,如果我们没有加‘’号,传给function的参数程序会定义成:变量,进入方法的时候,就会尝试获取这个变量名所对应的value,如果该变量没有被定义,就会报missing ) after argument list错误,如果加了‘’号,程序就会直接将该传参作为一个常数赋值给参数名,传参成功!