如何将option里面的value值,通过ajax提交到后台

mui.ajax({
                type:'get',
                dataType:'json',
                url:classifyUrl,
                success:function(data){
                    var len = data.length;
                    for(var i=0; i<len; i++){
                    var option = doc.createElement("option");                    
                    option.innerHTML = '<option value="">'+data[i].label+'</option>';                    
                    option.value = data[i].value;
                    currentIssueType = list.options[list.selectedIndex].value;
                    list.appendChild(option);
                    list.onchange = function(){
                    mui.alert(list.options[list.selectedIndex].value);
                    }
                    }
                }
            })        
        
            

            
//            部门分类
            mui.ajax({
                type:'get',
                dataType:'json',
                url:officeUrl,
                success:function(data){
                    var len = data.length;
                    for(var i=1; i<len; i++){
                    var option = doc.createElement("option");                    
                    option.innerHTML = '<option value="">'+data[i].name+'</option>';
                    option.value = data[i].name;
                    currentIssueType2 = list2.options[list2.selectedIndex].value;
                    list2.appendChild(option);
                    list2.onchange = function(){
                    mui.alert(list2.options[list2.selectedIndex].value);
                    }
                    }
                }
            })
            
            
            deliverButton.addEventListener('tap',function(event){
                var id = getQueryString("id");
                var deliverUrl = baseServerUrl+"/m/biz/issue/transmit?id="+id+"&issueType="+currentIssueType+"&officeId="+currentIssueType2;
                mui.ajax({
                    type:'get',
                    dataType:'json',
                    url:deliverUrl,
                    success:function(data){
                        alert(currentIssueType);
                        alert(currentIssueType2);
                    }
                })
            })
            
            

能看到alert出你的选择,但是在deliverButton里面提交的时候, alert(currentIssueType); alert(currentIssueType2);输出的却是第一个option里面的东西,怎么才能正常提交呢,球大神指教

阅读 4.2k
2 个回答

currentIssueType在deliverButton调用之前没有明确的赋值。下面是我找到的一个赋值的位置,你把这个改成同步的试试。你这个应该在上面两个ajax都执行完的时候,再去执行第三个ajax才可以有值

clipboard.png

clipboard.png

我觉得你应该分别在 onchange 里面去改变 currentIssueType 和 currentIssueType2

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题