【最基本的彈出窗口代碼】
成都創(chuàng)新互聯(lián)是一家從事企業(yè)網(wǎng)站建設(shè)、成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、行業(yè)門戶網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計制作的專業(yè)網(wǎng)站制作公司,擁有經(jīng)驗豐富的網(wǎng)站建設(shè)工程師和網(wǎng)頁設(shè)計人員,具備各種規(guī)模與類型網(wǎng)站建設(shè)的實力,在網(wǎng)站建設(shè)領(lǐng)域樹立了自己獨特的設(shè)計風(fēng)格。自公司成立以來曾獨立設(shè)計制作的站點近千家。
SCRIPT LANGUAGE="javascript"
!--
window.open ('page.html')
--
/SCRIPT
因為這是一段javascript代碼,所以它們應(yīng)該放在SCRIPT LANGUAGE ="javascript"標(biāo)簽和/script之間。
!--和--是對一些版本低的瀏覽器起作用,在這些老瀏覽器中如果不支持javascript,不會將標(biāo)簽中的代碼作
為文本顯示出來。
Window.open ('page.html')用于控制彈出新的窗口page.html,如果page.html不與主窗口在同一路徑下,前面
應(yīng)寫明路徑,絕對路徑(http://)和相對路徑(../)均可。
用單引號和雙引號都可以,只是不要混用。
這一段代碼可以加入HTML的任意位置,加入到head和/head之間也可以,位置越靠前執(zhí)行越早,尤其是頁面
代碼較長時,又想使頁面早點彈出就盡量往前放。
【經(jīng)過設(shè)置后的彈出窗口】
下面再說一說彈出窗口外觀的設(shè)置。只要再往上面的代碼中加一點東西就可以了。
我們來定制這個彈出窗口的外觀、尺寸大小、彈出位置以適應(yīng)該頁面的具體情況。
SCRIPT LANGUAGE="javascript"
!--
window.open('page.html','newwindow','height=100,width=400,top=0,left=0,toolbar=no,menubar=no,scrollbars=no, resizable=no,location=no,status=no')
//寫成一行
--
/SCRIPT
參數(shù)解釋:
SCRIPT LANGUAGE="java script" js腳本開始;
window.open 彈出新窗口的命令;
page.html 彈出新窗口的文件名;
newwindow 彈出窗口的名字(不是文件名),可用空 〃代替;
height=100 窗口高度;
top=0 窗口距離屏幕上方的像素值;
left=0 窗口距離屏幕左側(cè)的像素值;
toolbar=no 是否顯示工具欄,yes為顯示;
menubar,scrollbars 表示菜單欄和滾動欄;
resizable=no 是否允許改變窗口大小,yes為允許;
location=no 是否顯示地址欄,yes為允許;
status=no 是否顯示狀態(tài)欄內(nèi)的信息(通常是文件已經(jīng)打開),yes為允許;
/SCRIPT js腳本結(jié)束。
【用函數(shù)控制彈出窗口】
下面是一個完整的代碼。
html
head
script LANGUAGE="javascript"
!--
function openwin(){
window.open("page.html","newwindow","height=100,width=400,toolbar=no,menubar=no,scrollbars=no, resizable=no,location=no,status=no";)
//寫成一行
}
--
/script
/head
body onload="openwin()"
...任意的頁面內(nèi)容...
/body
/html
這里定義了一個函數(shù)openwin(),函數(shù)內(nèi)容就是打開一個窗口。在調(diào)用它之前沒有任何用途。怎么調(diào)用呢?
方法一:body onload="openwen()" 瀏覽器讀頁面時彈出窗口;
方法二:body onunload="openwen()" 瀏覽器離開頁面時彈出窗口;
方法三:用一個連接調(diào)用:a href="#" onclick="openwin()"打開一個窗口/a
注意:使用的"#"是虛連接。
方法四:用一個按鈕調(diào)用:input type="button" onclick="openwin()" value="打開窗口"
【主窗口打開文件1.htm,同時彈出小窗口page.html】
將如下代碼加入主窗口head區(qū):
script language="javascript"
!--
function openwin(){
window.open("page.html","","width=200,height=200";)
}
//--
/script
加入body區(qū):a href="1.htm" onclick="openwin()"open/a即可。
【彈出的窗口之定時關(guān)閉控制】
下面我們再對彈出窗口進行一些控制,效果就更好了。如果我們再將一小段代碼加入彈出的頁面(注意是加入到page.html的HTML中,可不是主頁面中,否則…),讓它在10秒鐘后自動關(guān)閉是不是更酷了?
首先,將如下代碼加入page.html文件的head區(qū):
script language="javascript"
function closeit() {
setTimeout("self.close()",10000) //毫秒
}
/script
然后,再用body onload="closeit()"這一句話代替page.html中原有的BODY這一句就可以了。(這一句話千
萬不要忘記寫?。∵@一句的作用是調(diào)用關(guān)閉窗口的代碼,10秒鐘后就自行關(guān)閉該窗口。)
【在彈出窗口中加上一個關(guān)閉按鈕】
form
INPUT TYPE='BUTTON' value='關(guān)閉' onClick='window.close()'
/form
呵呵,現(xiàn)在更加完美了!
【內(nèi)包含的彈出窗口——一個頁面兩個窗口】
上面的例子都包含兩個窗口,一個是主窗口,另一個是彈出的小窗口。
通過下面的例子,你可以在一個頁面內(nèi)完成上面的效果。
html
head
SCRIPT LANGUAGE="javascript"
function openwin()
{
OpenWindow=window.open("","newwin","height=250,width=250,toolbar=no,scrollbars="+scroll+",menubar=no";);
//寫成一行
OpenWindow.document.write("TITLE例子/TITLE";)
OpenWindow.document.write("BODY BGCOLOR=#FFFFFF";)
OpenWindow.document.write("H1Hello!/h1";)
OpenWindow.document.write("New window opened!";)
OpenWindow.document.write("/BODY ";)
OpenWindow.document.write("/HTML";)
OpenWindow.document.close()
}
/script
/head
body
a href="#" onclick="openwin()"打開一個窗口/a
input type="button" onclick="openwin()" value="打開窗口"
/body
/html
看看OpenWindow.document.write()里面的代碼不就是標(biāo)準(zhǔn)的HTML嗎?只要按照格式寫更多的行即可。千萬注意多一個標(biāo)簽或少一個標(biāo)簽都會出現(xiàn)錯誤。記住用OpenWindow.document.close()結(jié)束啊。
【終極應(yīng)用——彈出窗口的Cookie控制】
回想一下,上面的彈出窗口雖然酷,但是有一點小毛病(你沉浸在喜悅之中,一定沒有發(fā)現(xiàn)吧?)比如你將上面的腳本放在一個需要頻繁經(jīng)過的頁面里(例如首頁),那么每次刷新這個頁面,窗口都會彈出一次,是不是非常煩人?有解決的辦法嗎?Yes!Follow me。我們使用Cookie來控制一下就可以了。
首先,將如下代碼加入主頁面HTML的HEAD區(qū):
script
function openwin(){
window.open("page.html","","width=200,height=200" ;)
}
function get_cookie(Name){
var search = Name+ "="
var returnvalue ="";
if (documents.cookie.length 0){
offset = documents.cookie.indexOf(search)
if (offset!=-1){
offset += search.length
end = documents.cookie.indexOf (";",offset);
if (end ==-1)
end = documents.cookie.length;
returnvalue =unescape(documents.cookie.substring(offset,end))
}
}
return returnvalue;
}
function loadpopup(){
if (get_cookie(’popped’)==";){
openwin()
documents.cookie="popped=yes"
}
}
/script
然后,用body onload="loadpopup()"(注意不是openwin 而是loadpop?。┨鎿Q主頁面中原有的BODY這一句即可。你可以試著刷新一下這個頁面或重新進入該頁面,窗口再也不會彈出了。真正的Pop-Only-Once!
寫到這里,彈出窗口的制作和應(yīng)用技巧基本上算是講完了,希望對正在制作網(wǎng)頁的朋友有所幫助我就非常欣慰了。
需要注意的是,JS腳本中的大小寫最好前后保持一致。
沒有菜單、工具欄、地址欄的彈出窗口:
script language="javascript"
!--
var gt = unescape('%3e');
var popup = null;
var over = "Launch Pop-up Navigator";
popup = window.open('', 'popupnav', 'width=500,height=500,resizable=0,scrollbars=auto'); // width=500,height=500為窗口長和寬
if (popup != null) {
if (popup.opener == null) {
popup.opener = self; }
popup.location.href = '要打開的文件名';
}
// --
/script
離開一個頁面時彈出一個可定制的窗口
!-- Begin
function leave() {
window.open(\'離開頁面時彈出窗口的URL\',\'\',\'toolbar=no,menubar=no,location=no,height=235,width=320\');
}
// End --
/script
如下代碼加入HTML的BODY區(qū):body onUnload="leave()"
超級彈窗代碼(MYIE也照彈)
script language="javascript"
focusid=setTimeout("focus();window.showModelessDialog(\'\',\'\',\'scroll:1;status:0;help:0;resizable:1;dialogWidth:0px;dialogHeight:0px\')",0000)
/script
script language="javascript"
!--
function clock(){i=i-1
document.title="";#定義標(biāo)題
if(i0)setTimeout("clock();",1000);
else self.close();}
var i=4#定義多少秒后關(guān)
clock();
//--
/script
告訴你為什么樓上答案都這么長,因為他們只懂copy別人的。。
我專門寫了個給你:
Test.java
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
public class Test {
public static void main(String[] args) {
new MyFrame();
}
}
class MyFrame extends JFrame {
public MyFrame() {
Container c = this.getContentPane();
c.setLayout(new FlowLayout());
JButton button = new JButton("點擊");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
String message = "hi";//這句為你要顯示的值
JOptionPane.showMessageDialog(rootPane, message);
}
});
c.add(button);
this.setSize(300, 200);
this.show();
}
}
其中輸入消息的關(guān)鍵語句是:
JOptionPane.showMessageDialog(rootPane, message);
我不確定你說的“彈出一個文本框”是不是這個意思,如果不是的話補充一下問題我?guī)湍愀陌伞?/p>
代碼缺一行:
。。。
authorTextArea.setPreferredSize(new Dimension(40, 80));
authorFrame.add(authorTextArea);
。。。
以上完了后,需要加一個
authorFrame.setVisible(true);
至于這個框的大小,你再調(diào)調(diào)哈,相互學(xué)習(xí)~,三年沒做過了~
JAVA彈窗,有下面常見的2種方法實現(xiàn):
通過JDialog(模式窗口) 類來實現(xiàn).里面的寫法類似JFrame
重點方法提示:?setModal(true);
//當(dāng)設(shè)置為true表示,如果不關(guān)閉這個彈窗,那么主界面的其他組件都無法操作,該彈窗置于其他窗口的前面
//當(dāng)設(shè)置為false表示,可以繞開本彈窗,對主界面的其他組件進行操作
優(yōu)點: 功能強大, ?擴展性強
缺點: 代碼量大.
示例圖
通過JOptionPane(提示框) 來實現(xiàn)
效果圖如下
優(yōu)點: 代碼量少,簡單,方便, 普通場景已經(jīng)夠用
缺點: 擴展性不夠, 復(fù)雜邏輯難以實現(xiàn).
下面寫一個具體案例
場景:當(dāng)用于對文本域的文字,進行操作后,那么退出時,提示用戶, 是否要保存已經(jīng)更改后的內(nèi)容. ?如果用戶沒有修改內(nèi)容,那么不用提示
重點代碼
addDocumentListener--用于實現(xiàn)對文本內(nèi)容發(fā)生改變時進行響應(yīng)
addWindowListener---用于實現(xiàn)對窗口進行操作時進行響應(yīng)
完整代碼如下
import?java.awt.Font;
import?java.awt.event.*;
import?javax.swing.*;
import?javax.swing.event.*;
public?class?JDDemo?extends?JFrame?implements?DocumentListener,WindowListener{
JTextArea?jta;
boolean?flag;
public?JDDemo()?{
jta?=?new?JTextArea();//文本域
jta.setText("床前明月光");//文本域的文字--可以通過IO加載txt文檔的文字
jta.setFont(new?Font("宋體",Font.BOLD,?20));//文本域的字體
jta.setLineWrap(true);//設(shè)置自動換行
jta.getDocument().addDocumentListener(this);//添加文檔變化事件的響應(yīng).比如修改,刪除等
JScrollPane?jsp?=?new?JScrollPane(jta);//滾動面板(當(dāng)文字太多時,顯示滾動條)
add(jsp);
setTitle("主窗口");//標(biāo)題
setSize(300,?260);//大小
setLocationRelativeTo(null);//居中
setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);//點擊窗口的關(guān)閉按鈕時,執(zhí)行windowClosing的代碼
addWindowListener(this);
setVisible(true);//窗口可見
}
public?static?void?main(String[]?args)?{
new?JDDemo();
}
//實現(xiàn)WindowListener接口,需要重寫下面的6個方法,?windowClosing專門處理關(guān)閉時的方法
public?void?windowOpened(WindowEvent?e)?{
}
public?void?windowClosing(WindowEvent?e)?{
if(flag){
int?n?=?JOptionPane.showConfirmDialog(null,?"已經(jīng)更改了內(nèi)容,需要保存后再退出嗎?",?"提示",JOptionPane.YES_NO_OPTION);
//n等于-1表示關(guān)閉了彈出的對話框等情況的默認(rèn)值
//n等于0(JOptionPane.YES_OPTION)表示選擇了Yes
//n等于1(JOptionPane.NO_OPTION)表示選擇了No
if(n==JOptionPane.YES_OPTION){
//把文字保存到文件的代碼省略...
System.out.println("正在使用IO進行保存..ing");
closeFrame();//關(guān)閉窗口并退出
}else?if(n==JOptionPane.NO_OPTION){
System.out.println("放棄保存修改.馬上退出");
closeFrame();
}
}else{
closeFrame();
}
}
public?void?windowClosed(WindowEvent?e)?{
}
public?void?windowIconified(WindowEvent?e)?{
}
public?void?windowDeiconified(WindowEvent?e)?{
}
public?void?windowActivated(WindowEvent?e)?{
}
public?void?windowDeactivated(WindowEvent?e)?{
}
//文檔事件,有下面三個,如果觸發(fā)其中一個,都可以認(rèn)為修改了文檔,所以需要在退出時進行提示,是否保存
public?void?insertUpdate(DocumentEvent?e)?{//插入
flag=true;
}
public?void?removeUpdate(DocumentEvent?e)?{//刪除
flag=true;
}
public?void?changedUpdate(DocumentEvent?e)?{//改變
flag=true;
}
//關(guān)閉窗口的方法
public?void?closeFrame(){
this.setVisible(false);//窗口不可見
this.dispose();//窗口銷毀
System.exit(0);//JVM虛擬機退出
}
}
運行效果圖:
名稱欄目:java彈出窗口的代碼 java彈出對話框的三個命令
本文來源:http://chinadenli.net/article40/ddegceo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、企業(yè)建站、商城網(wǎng)站、網(wǎng)站制作、網(wǎng)站導(dǎo)航、網(wǎng)站維護
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)