1

green.png をクリックすると red.png に変わります。しかし、ページを読み込んですでに red.png として設定されている場合、変更する前に img を 2 回クリックする必要があります。1 回だけクリックしたいと思います。

    $(".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'))
    });

どうすればこれを改善できますか?

4

1 に答える 1

1

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、デフォルトで赤または青で構成されていることを示すクラスがあります。

于 2013-02-09T03:44:11.633 に答える