Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7008455
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T21:44:13+00:00 2026-05-27T21:44:13+00:00

I have seen the oddest behavior from JavaScript and would love some insight into

  • 0

I have seen the oddest behavior from JavaScript and would love some insight into what is causing this. I made a little sudoku solver app (code below, also available to see at wellsjohnston.com/projects), and part of it features a board generator. When you click ‘generate board’ or ‘solve’, jQuery is supposed to change the button to say “Creating Random Board…” or ‘solving…’. However, when they are clicked, nothing happens. You would think it was simply not working – but that is not the case. When I remove the code to change the button back (ie, removing $(‘.submit_sudoku_board’).text(‘solve’), it all of a sudden works, and changes when clicked (but not back, of course). Does anyone have any idea what is going on??

TL;DR:The code seems to be executing asynchronously. While the solving/board generating recursive functions are running, the rest of the script executes. Why??

Thank you!

EDIT: added HTML code as well. Sorry if it is ugly…

$(function(){
    $('.submit_sudoku_board').click(function(){
        $('.submit_sudoku_board').text('Solving...');
        sudoku();
        $('.submit_sudoku_board').text('Solve');
    });
    $('.clear_board').click(function(){
        $('.board_input').val('');
        });
    $('.generate_board').click(function(){
        $('.board_input').val('');
        $('.generate_board').text('Creating Random Board...');
        console.log('creating random board...')
        generate_random_board();
        console.log('------done creating board-----');
    });
});

function sudoku()
{
    var sudoku_board = new Array(9);
    for(var i = 0; i < 9; i++){
        sudoku_board[i] = new Array(9);
    }

    var cell, valid = true;
    for(i = 0; i < 9; ++i)
    {
        for(var j = 0; j < 9; ++j)
        {
            cell = '#r' + i + 'c' + j;
            if($(cell).val())
            {
                if(!($(cell).val() > 0 && $(cell).val() < 10))
                {
                    $('.sudoku_message_box').text("Illegal characer found");
                    valid = false;
                    break;
                }
                sudoku_board[i][j] = ($(cell).val());  
            }else{
                sudoku_board[i][j] = 0;
            }
        }
    }
    if(valid)
    {
        var start = new Date().getTime();
        var solved = sudoku_solver(sudoku_board, 0, 0);
        var end = new Date().getTime();
        var solve_time = (end - start)/1000.0;
        if(solved)
        {
            fill_board(sudoku_board);
            $('.sudoku_message_box').text("Solve time: " + solve_time + " seconds");
            $('.submit_sudoku_board)').text('Solve');
        }else{
            $('.sudoku_message_box').text("Sudoku puzzle not solvable");
        }
    }
}

function sudoku_solver(board, row, col){
    if(row == 9)
    {
        return true;
    }else if(col == 9)
    {
        return sudoku_solver(board, row + 1, 0);
    }else if(board[row][col] != 0)
    {
        return sudoku_solver(board, row, col + 1);
    }

    for(var i = 1; i < 10; i++)
    {
        if(can_go(board, row, col, i))
        {
            board[row][col] = i;
            if(sudoku_solver(board, row, col + 1))
            {
                return true;
            }
        }
    }
    board[row][col] = 0;
    return false;
}

function can_go(board, row, col, val){
    for(var i = 0; i < 9; i++)
    {
        if(board[row][i] == val || board[i][col] == val)
        {
            return false;
        }
    }
    var subgrid_row;
    var subgrid_col;

    if(row < 3)
    {
        subgrid_row = 0;
    }else if(row > 5)
    {
        subgrid_row = 6;
    }else{
        subgrid_row = 3;
    }

    if(col < 3)
    {
        subgrid_col = 0;
    }else if(col > 5)
    {
        subgrid_col = 6;
    }else{
        subgrid_col = 3;
    }

    for(i = subgrid_row; i <= subgrid_row + 2; i++)
    {
        for(var j = subgrid_col; j <= subgrid_col + 2; j++)
        {
            if(board[i][j] == val)
            {
                return false;
            }
        }
    }
    return true;
}

function fill_board(board){
    var cell;
    for(i = 0; i < 9; ++i)
    {
        for(j = 0; j < 9; ++j)
        {
            if(board[i][j] != 0)
            {
                cell = '#r' + i + 'c' + j;
                ($(cell).val(board[i][j]));
            }

        }
    }
}

function generate_random_board(){
    var sudoku_board = new Array(9), dummy_board = new Array(9);
    for(var i = 0; i < 9; i++){
        sudoku_board[i] = new Array(9);
        dummy_board[i] = new Array(9);
    }
    for(i = 0; i < 9; ++i)
    {
        for(var j = 0; j < 9; ++j)
        {
            sudoku_board[i][j] = 0;
            dummy_board[i][j] = 0;
        }
    }
    var random_range = Math.floor(Math.random()*10)+ 30;
    for(i = 0; i < random_range; i++)
    {
        var random_x=Math.floor(Math.random()*8) + 1; // generate a random number 1-9
        var random_y =Math.floor(Math.random()*8) + 1; 
        var random_val =Math.floor(Math.random()*8) + 1; 
        if(can_go(sudoku_board, random_x, random_y, random_val))
        {
            sudoku_board[random_x][random_y] = random_val;
            dummy_board[random_x][random_y] = random_val;
        }
    }
    console.log('solving test board');
    var solvable = sudoku_solver(dummy_board, 0, 0);
    console.log('iteration complete');
    if(solvable)
    {
        console.log('found board');
        $('.generate_board').text('Generate Solvable Board');
        fill_board(sudoku_board);
    }else{
        console.log('board failed');
        $('.generate_board').text('board not found');
        $('.board_input').val('');
        generate_random_board();
    }
}





     <div class="sudoku">
                            <div class="sudoku_title">
                                Sudoku Solver in JavaScript
                            </div>
                            <form style="position:relative; left:20%; top:25px;">
    <table cellspacing=0 cellpadding=0 border=1 style="background-color:#FFFFFF;">
        <!-- row 0 -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" maxlength="1" type="text" id="r0c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r0c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r0c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r0c8" size="20" /></td>
        </tr> 
        <!-- row 1   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r1c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r1c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r1c8" size="20" /></td>
        </tr> 
        <!-- row 2   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r2c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r2c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r2c8" size="20" /></td>
        </tr>
        <!-- row 3   -->
        <tr>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c0" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1"  type="text" id="r3c1" size="20" /></td>
            <td class="board board_horizontal board_vertical"><input class ="board_input" maxlength="1" type="text" id="r3c2" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c3" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c4" size="20" /></td>
            <td class="board board_horizontal board_vertical"><input class ="board_input" maxlength="1" type="text" id="r3c5" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c6" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c7" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r3c8" size="20" /></td>
        </tr> 
        <!-- row 4   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r4c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r4c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r4c8" size="20" /></td>
        </tr> 
        <!-- row 5   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r5c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r5c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r5c8" size="20" /></td>
        </tr> 
        <!-- row 6   -->
        <tr>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c0" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c1" size="20" /></td>
            <td class="board board_horizontal board_vertical"><input class ="board_input" maxlength="1" type="text" id="r6c2" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c3" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c4" size="20" /></td>
            <td class="board board_horizontal board_vertical"><input class ="board_input" maxlength="1" type="text" id="r6c5" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c6" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c7" size="20" /></td>
            <td class="board board_horizontal"><input class ="board_input" maxlength="1" type="text" id="r6c8" size="20" /></td>
        </tr> 
        <!-- row 7   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r7c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r7c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r7c8" size="20" /></td>
        </tr> 
        <!-- row 8   -->
        <tr>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c0" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c1" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r8c2" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c3" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c4" size="20" /></td>
            <td class="board board_vertical"><input class ="board_input" maxlength="1" type="text" id="r8c5" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c6" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c7" size="20" /></td>
            <td class="board"><input class ="board_input" maxlength="1" type="text" id="r8c8" size="20" /></td>
        </tr> 
        <!-- end rows -->
    </table> 
</form>
                            <div class="sudoku_bottom">
                                <div class="submit_sudoku_board">
                                    Solve
                                </div>
                                <div class="sudoku_message_box">
                                    Enter a Sudoku puzzle into the board
                                </div>
                            </div>
                            <div class="clear_board">
                                Clear Board
                            </div>
                            <div class="generate_board">
                                Generate Solvable Board
                            </div>
                        </div>
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T21:44:14+00:00Added an answer on May 27, 2026 at 9:44 pm

    In most browsers, Javascript runs on the GUI thread. If your script is running, the GUI will not be updated until your function returns.

    Allow the GUI to regain control and repaint with something like this, which delays doing the actual solve until after the GUI is updated:

    $('.submit_sudoku_board').click(function(){
        $('.submit_sudoku_board').text('Solving...');
        window.setTimeout(function() {
            sudoku();
            $('.submit_sudoku_board').text('Solve');
        }, 10);
    });
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have seen this problem arise in many different circumstances and would like to
Have seen this comment in a method: //I wonder why Sun made input and
Have seen some conversations revolving around this, but hoping for some current input as
I have seen this post: WPF ComboBox: background color when disabled and some others...
Have seen some similar questions: What is the difference between a JavaBean and a
I have seen examples of printing from a windows application but I have not
I have seen a few mentions of this idiom (including on SO ): //
I have seen the official demos on lwjgl.org but I would like to see
I have seen this example: http://jsfiddle.net/UwEe2/306/ that is implemented with scrollleft . Now I
I have seen this line of code in several tutorials for using Unity in

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.