How to do Threading in Javascript

前端 未结 4 1937
栀梦
栀梦 2020-12-06 05:53

So I have a large JSON object i\'m returning from the server, then building a datatable from it and displaying it on the form. This usually takes a few seconds.. so I was th

相关标签:
4条回答
  • 2020-12-06 05:56

    If you do all the building of the Database in a setTimeout, the rest of the page should be responsive.

    You can construct the html elements in that function, and when it is ready, attach it to the DOM. You will also have to call functions or send events to update the display of the progress bar.

    Edit after comment:

    This will run in background and won't affect responsiveness of the page:

    window.setTimeout(function() {buildDataTable(db_table, container_id)}, 0);

    You already update your progressbar from your function, so this should do it.

    However, you might want to decouple the code generating the datatable from the code updating the progressbar.

    0 讨论(0)
  • 2020-12-06 06:06

    [Added my comment as an answer]

    JavaScript is single threaded. You'll have to break your work up into pieces and call them in sequence using "setTimeout" to allow the GUI to update during processing (in between your calls) but even then the browser will still seem somewhat unresponsive.

    0 讨论(0)
  • 2020-12-06 06:06

    You can try using WebWorker: https://developer.mozilla.org/en/DOM/Worker
    Thus worker are executed in parallel of the main thread, you cannot exactly achieve multi-threading using workers: you cannot modify the UI from a worker.
    You can maybe create your grid as a string in a worker and when the worker finish, append it where you want.

    0 讨论(0)
  • 2020-12-06 06:08

    So it appears the only clean way to do this in my application is to process the json on the server and build the html there. Then return the html to the browser via $.post()

    The progress bar will be lost. however I can use a infinite loading gif...

    0 讨论(0)
提交回复
热议问题