登录

javascript - jquery中change事件里面if语句失效

<p class="add-new-img mt-2">
    <select name="picType" id="img-type">
        <option value="0">彩色</option>
        <option value="1">黑白</option>
    </select>
</p>
<p class="add-new-img mt-2">
    <select name="picType" id="img-type-classify">
    </select>
</p>

两个下拉框 给第一个下拉框change事件 请求不同的ajax地址 改变第二个下拉框的数据

$("#img-type").change(function(){
        console.log($(this).val())
        if($(this).val()===1){
            console.log(1)
            $.ajax({
            type : 'GET',
            data: {
                'type': '2',
                "type_classify":1
            },
            url: "/Type/getTypeList",
            dataType: "json",
            success: function(data){
                var color = ["彩色","黑白"]

                var options='';
                for(var i=0;i<data.data.length;i++){
                     var num = Number(data.data[i].type_classify)
                    options += '<option value='+data.data[i].id+'>'+data.data[i].id+data.data[i].type_name+"("+color[num]+")"+'</option>';                                     
                }
                $("#img-type-classify").html(options);
                },
              error:function(msg){
                console.log(msg);
            },
        });
        }
        if($(this).val()===0){
            console.log(0)
            $.ajax({
            type : 'GET',
            data: {
                'type': '2',
                "type_classify":0
            },
            url: "/Type/getTypeList",
            dataType: "json",
            success: function(data){
                var color = ["彩色","黑白"]

                var options='';
                for(var i=0;i<data.data.length;i++){
                     var num = Number(data.data[i].type_classify)
                    options += '<option value='+data.data[i].id+'>'+data.data[i].id+data.data[i].type_name+"("+color[num]+")"+'</option>';                                     
                }
                $("#img-type-classify").html(options);
                },
              error:function(msg){
                console.log(msg);
            },
        });
        }
    })

判断第一个下拉框的value值请求不同的后台接口 但是console出了$(this).val()是正常的 但是在if语句里面console就没有效果 请问是什么原因

# JavaScript
巴扎黑 巴扎黑 2279 天前 456 次浏览

全部回复(2) 我要回复

  • 大家讲道理

    大家讲道理2017-05-19 10:12:24

    if($(this).val()==='1')

    回复
    0
  • 怪我咯

    怪我咯2017-05-19 10:12:24

    0和1都是字符串吧,你用的又是===,so……

    回复
    0
  • 取消 回复 发送