为什么动态绑定click事件后,没有点击就已经触发了方法?

 

错误代码:

$("#id").on('click',cr());

 

function cr(){

          方法体;

}

 

原因:因为在绑定事件时先执行了方法,再将结果返回到调用方法中。

 

 

解决:将方法写到回调函数中

$("#id").on('click',function(){

          方法体;

})

 

 

 

外层方法参数向内层方法传递参数,可直接传入,不需要再声明变量

function setMarker(lnglats,icon,info,flag,changeIcon) {
    var marker = new AMap.Marker({
        position: lnglats,
        map: map,
        icon:icon,
        topWhenClick:true
    });
    if(null!=info && ""!=info){
        marker.content = info.join("");
        if(flag){   //选中变图标
            marker.on('click', function (marker) {
                defaultIcon();
                marker.target.setIcon(changeIcon) ;
                infoWindow.setContent(marker.target.content);
                infoWindow.open(map,marker.target.getPosition());
                iconArray = icon;
                lnglatsArray = marker;
            });
        } else{ //选中不变图标
            marker.on('click', function (marker) {
                defaultIcon();
                infoWindow.setContent(marker.target.content);
                infoWindow.open(map, marker.target.getPosition());
                conArray = icon;
                lnglatsArray = marker;
            });
        }
    }

};
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值