jQuery Img切换Ajax帖子

jQuery Img toggle Ajax post

本文关键字:帖子 Ajax 切换 Img jQuery      更新时间:2023-09-26

我有两个图像,当我点击green.png时,它会变成red.png。但当我加载页面时,它已经设置为red.png,我需要点击img两次,然后它才会改变。我只想点击一次。

    $(".page-state").toggle(function(event){
    this.src = "images/red.png";
        var id = event.target.id; //the Div ID variable         
        var dataString = 'page='+ id + '&view=off';         
        $.ajax({
            type: "POST",
            url: "pageState.php",
            data: dataString,
            cache: false,
        });
        $('#mainFrame')
        .attr('src', $('iframe')
        .attr('src'))
    }, function(event) { 
        this.src = "images/green.png";
        var id = event.target.id; //the Div ID variable         
        var dataString = 'page='+ id + '&view=on';          
        $.ajax({
            type: "POST",
            url: "pageState.php",
            data: dataString,
            cache: false,
        });
        $('#mainFrame')
        .attr('src', $('iframe')
        .attr('src'))
    });

我该如何改进?

jQuery:

$(".page-state").click( function() {
    var s = $(this).attr("class").split(" ");
    if(s[1] == 'red') {
        this.src = 'green.png';
        $(this).removeClass('red').addClass('green');
        // more code for green
    }
    else {
        this.src = 'red.png';
        $(this).removeClass('green').addClass('red');
        // more code for red image
    }
});

HTML:

<img class="page-state red" src="red.png" />

正如您所看到的,.page-state有一个类,它表示默认情况下由红色或蓝色组成。