ページに「データがロードされています.待ってください...Loading,please wait...」ダイアログを呼び出す

6345 ワード

例えば、Asp.Netページの1つのボタンをクリックした後に長い時間操作してやっと反応があって、フロントに“データがロードしているので、待ってください...Loading,please wait...”のヒントを出力する必要があります.実装方法はたくさんあります.一部のコントロールは直接パッケージされています.例えばExtJSはparentPanelだけです.body.mask('データがロードされています.待ってください...Loading,please wait...','x-mask-loading')、マウント完了parentPanelを呼び出します.body.unmask();できます.ここでは、隠しdivレイヤを追加し、buttonをクリックして表示し、ロードが完了したら隠します.
   1: <div id="doing" runat="server" style="Z-INDEX: 12000; LEFT: 0px; VISIBILITY: hidden; WIDTH: 100%;  POSITION: absolute; TOP: 100px; HEIGHT: 100%">
   2:    <table width="100%" height="100%">
   3:        <tr align="center" valign="top">
   4:            <td style="height: 792px">
   5:                <table width="169" class="font3" bgcolor="orange" style="FILTER: Alpha(Opacity=75); WIDTH: 169px; HEIGHT: 40px">
   6:                    <tr align="center" valign="middle">
   7:                        <td style="width: 266px;font-size:11px;font-weight:bold;font-family: Arial;color:#FFFFFF">Loading ...<br>
   8:                            One moment please...
   9:                        </td>
  10:                    </tr>
  11:                </table>
  12:            </td>
  13:        </tr>
  14:    </table>
  15: </div>
  16:  
Page_ロードにはこう書いてあります.
   1: //
   2: this.Button1.Attributes.Add("onclick","document.getElementById('doing').style.visibility='visible';"); 
   3: //
   4: //
   5: //
操作が終了してリダイレクトした後、ページが再ロードされると、このレイヤは消えます.手動で消すこともできます.
   1: //
   2: document.getElementById('doing').style.visibility='hidden';
   3: //