JS瀏覽器BOM常見(jiàn)操作實(shí)例詳解
本文實(shí)例講述了JS瀏覽器BOM常見(jiàn)操作。分享給大家供大家參考,具體如下:
window尺寸有三種方法能夠確定瀏覽器窗口的尺寸(瀏覽器的視口,不包括工具欄和滾動(dòng)條)。
對(duì)于Internet Explorer、Chrome、Firefox、Opera 以及 Safari:
window.innerHeight - 瀏覽器窗口的內(nèi)部高度 window.innerWidth - 瀏覽器窗口的內(nèi)部寬度
對(duì)于 Internet Explorer 8、7、6、5:
document.documentElement.clientHeight document.documentElement.clientWidth
或者
document.documentElement.clientHeight document.documentElement.clientWidth
實(shí)用的 JavaScript 方案(涵蓋所有瀏覽器):
<script> var w=window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; var h=window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; x=document.getElementById('demo'); x.innerHTML='瀏覽器window寬度: ' + w + ', 高度: ' + h + '。' </script>
其他 Window 方法
window.open() - 打開(kāi)新窗口 window.close() - 關(guān)閉當(dāng)前窗口 window.moveTo() - 移動(dòng)當(dāng)前窗口 window.resizeTo() - 調(diào)整當(dāng)前窗口的尺寸 Window Screen
window.screen對(duì)象在編寫(xiě)時(shí)可以不使用 window 這個(gè)前綴。
screen.availWidth - 可用的屏幕寬度 screen.availHeight - 可用的屏幕高度
Window Screen 可用寬度
screen.availWidth 屬性返回訪問(wèn)者屏幕的寬度,以像素計(jì),減去界面特性,比如窗口任務(wù)欄。
Window Screen 可用高度
screen.availHeight 屬性返回訪問(wèn)者屏幕的高度,以像素計(jì),減去界面特性,比如窗口任務(wù)欄。
Window Locationlocation.hostname 返回 web 主機(jī)的域名 location.pathname 返回當(dāng)前頁(yè)面的路徑和文件名 location.port 返回 web 主機(jī)的端口 (80 或 443) location.protocol 返回所使用的 web 協(xié)議(http:// 或 https://) location.href 屬性返回當(dāng)前頁(yè)面的 URL。 location.pathname 屬性返回 URL 的路徑名。 location.assign() 方法加載新的文檔。 Window History
history.back() - 與在瀏覽器點(diǎn)擊后退按鈕相同 history.forward() - 與在瀏覽器中點(diǎn)擊按鈕向前相同 JavaScript Navigator
window.navigator 對(duì)象包含有關(guān)訪問(wèn)者瀏覽器的信息。
警告!!!來(lái)自 navigator 對(duì)象的信息具有誤導(dǎo)性,不應(yīng)該被用于檢測(cè)瀏覽器版本,這是因?yàn)椋?/p>
navigator 數(shù)據(jù)可被瀏覽器使用者更改
一些瀏覽器對(duì)測(cè)試站點(diǎn)會(huì)識(shí)別錯(cuò)誤
瀏覽器無(wú)法報(bào)告晚于瀏覽器發(fā)布的新操作系統(tǒng)
JavaScript 彈窗可以在 JavaScript 中創(chuàng)建三種消息框:警告框、確認(rèn)框、提示框。
警告框警告框經(jīng)常用于確保用戶可以得到某些信息。
當(dāng)警告框出現(xiàn)后,用戶需要點(diǎn)擊確定按鈕才能繼續(xù)進(jìn)行操作。
語(yǔ)法window.alert('sometext');
window.alert() 方法可以不帶上window對(duì)象,直接使用alert()方法。
確認(rèn)框確認(rèn)框通常用于驗(yàn)證是否接受用戶操作。
當(dāng)確認(rèn)卡彈出時(shí),用戶可以點(diǎn)擊 '確認(rèn)' 或者 '取消' 來(lái)確定用戶操作。
當(dāng)你點(diǎn)擊 '確認(rèn)', 確認(rèn)框返回 true, 如果點(diǎn)擊 '取消', 確認(rèn)框返回 false。
語(yǔ)法window.confirm('sometext');
window.confirm() 方法可以不帶上window對(duì)象,直接使用confirm()方法。
提示框提示框經(jīng)常用于提示用戶在進(jìn)入頁(yè)面前輸入某個(gè)值。
當(dāng)提示框出現(xiàn)后,用戶需要輸入某個(gè)值,然后點(diǎn)擊確認(rèn)或取消按鈕才能繼續(xù)操縱。
如果用戶點(diǎn)擊確認(rèn),那么返回值為輸入的值。如果用戶點(diǎn)擊取消,那么返回值為 null。
語(yǔ)法window.prompt('sometext','defaultvalue');
window.prompt() 方法可以不帶上window對(duì)象,直接使用prompt()方法。
換行彈窗使用 反斜杠 + 'n'(n) 來(lái)設(shè)置換行。
JavaScript 計(jì)時(shí)事件通過(guò)使用 JavaScript,我們有能力作到在一個(gè)設(shè)定的時(shí)間間隔之后來(lái)執(zhí)行代碼,而不是在函數(shù)被調(diào)用后立即執(zhí)行。我們稱(chēng)之為計(jì)時(shí)事件。
在 JavaScritp 中使用計(jì)時(shí)事件是很容易的,兩個(gè)關(guān)鍵方法是:
setInterval() - 間隔指定的毫秒數(shù)不停地執(zhí)行指定的代碼。 setTimeout() - 暫停指定的毫秒數(shù)后執(zhí)行指定的代碼
Note: setInterval() 和 setTimeout() 是 HTML DOM Window對(duì)象的兩個(gè)方法。
setInterval() 方法setInterval() 間隔指定的毫秒數(shù)不停地執(zhí)行指定的代碼
語(yǔ)法window.setInterval('javascript function',milliseconds);
window.setInterval() 方法可以不使用window前綴,直接使用函數(shù)setInterval()。
setInterval() 第一個(gè)參數(shù)是函數(shù)(function)。第二個(gè)參數(shù)間隔的毫秒數(shù)
如何停止執(zhí)行?clearInterval() 方法用于停止 setInterval() 方法執(zhí)行的函數(shù)代碼。
語(yǔ)法window.clearInterval(intervalVariable)
window.clearInterval() 方法可以不使用window前綴,直接使用函數(shù)clearInterval()。
要使用 clearInterval() 方法, 在創(chuàng)建計(jì)時(shí)方法時(shí)你必須使用全局變量:
myVar=setInterval('javascript function',milliseconds);
然后可以使用clearInterval() 方法來(lái)停止執(zhí)行。
setTimeout() 方法語(yǔ)法window.setTimeout('javascript 函數(shù)',毫秒數(shù));
setTimeout() 方法會(huì)返回某個(gè)值。在上面的語(yǔ)句中,值被儲(chǔ)存在名為 t 的變量中。假如你希望取消這個(gè) setTimeout(),你可以使用這個(gè)變量名來(lái)指定它。
setTimeout() 的第一個(gè)參數(shù)是含有 JavaScript 語(yǔ)句的字符串。這個(gè)語(yǔ)句可能諸如 'alert(’5 seconds!’)',或者對(duì)函數(shù)的調(diào)用,諸如 alertMsg()'。
第二個(gè)參數(shù)指示從當(dāng)前起多少毫秒后執(zhí)行第一個(gè)參數(shù)。
如何停止執(zhí)行?clearTimeout() 方法用于停止執(zhí)行setTimeout()方法的函數(shù)代碼。
語(yǔ)法window.clearTimeout(timeoutVariable)
window.clearTimeout() 方法可以不使用window 前綴。
要使用clearTimeout() 方法, 你必須在創(chuàng)建超時(shí)方法中(setTimeout)使用全局變量:
myVar=setTimeout('javascript function',milliseconds);
如果函數(shù)還未被執(zhí)行,你可以使用 clearTimeout() 方法來(lái)停止執(zhí)行函數(shù)代碼。
JavaScript CookiesCookies 用于存儲(chǔ) web 頁(yè)面的用戶信息。
什么是 Cookies?Cookies 是一些數(shù)據(jù), 存儲(chǔ)于你電腦上的文本文件中。
當(dāng) web 服務(wù)器向?yàn)g覽器發(fā)送 web 頁(yè)面時(shí),在連接關(guān)閉后,服務(wù)端不會(huì)記錄用戶的信息。
Cookies 的作用就是用于解決 '如何記錄客戶端的用戶信息':
當(dāng)用戶訪問(wèn) web 頁(yè)面時(shí),他的名字可以記錄在 cookie 中。
在用戶下一次訪問(wèn)該頁(yè)面時(shí),可以在 cookie 中讀取用戶訪問(wèn)記錄。
Cookies 以名/值對(duì)形式存儲(chǔ),如下所示:
username=John Doe
當(dāng)瀏覽器從服務(wù)器上請(qǐng)求 web 頁(yè)面時(shí), 屬于該頁(yè)面的 cookies 會(huì)被添加到該請(qǐng)求中。服務(wù)端通過(guò)這種方式來(lái)獲取用戶的信息。
使用 JavaScript 創(chuàng)建CookieJavaScript 可以使用 document.cookie 屬性來(lái)創(chuàng)建 、讀取、及刪除 cookies。
JavaScript 中,創(chuàng)建 cookie 如下所示:
document.cookie='username=John Doe';
還可以為 cookie 添加一個(gè)過(guò)期時(shí)間(以 UTC 或 GMT 時(shí)間)。默認(rèn)情況下,cookie 在瀏覽器關(guān)閉時(shí)刪除:
document.cookie='username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT';
可以使用 path 參數(shù)告訴瀏覽器 cookie 的路徑。默認(rèn)情況下,cookie 屬于當(dāng)前頁(yè)面。
document.cookie='username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/';使用 JavaScript 讀取 Cookie
在 JavaScript 中, 可以使用以下代碼來(lái)讀取 cookies:
var x = document.cookie; document.cookie 將以字符串的方式返回所有的 cookies,類(lèi)型格式: cookie1=value; cookie2=value; cookie3=value; 使用 JavaScript 修改 Cookie
在 JavaScript 中,修改 cookies 類(lèi)似于創(chuàng)建 cookies,如下所示:
document.cookie='username=John Smith; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/';
舊的 cookie 將被覆蓋。
使用 JavaScript 刪除 Cookie刪除 cookie 非常簡(jiǎn)單。您只需要設(shè)置 expires 參數(shù)為以前的時(shí)間即可,如下所示,設(shè)置為 Thu, 01 Jan 1970 00:00:00 GMT:
document.cookie = 'username=; expires=Thu, 01 Jan 1970 00:00:00 GMT';
注意,當(dāng)您刪除時(shí)不必指定 cookie 的值。
設(shè)置 cookie 值的函數(shù)首先,我們創(chuàng)建一個(gè)函數(shù)用于存儲(chǔ)訪問(wèn)者的名字:
//cookie 的名稱(chēng)為 cname,cookie 的值為 cvalue,并設(shè)置了 cookie 的過(guò)期時(shí)間 expires。 function setCookie(cname,cvalue,exdays) { var d = new Date(); d.setTime(d.getTime()+(exdays*24*60*60*1000)); var expires = 'expires='+d.toGMTString(); document.cookie = cname + '=' + cvalue + '; ' + expires; } 獲取 cookie 值的函數(shù)
然后,我們創(chuàng)建一個(gè)函數(shù)用戶返回指定 cookie 的值:
function getCookie(cname) { var name = cname + '=';//創(chuàng)建一個(gè)文本變量用于檢索指定 cookie :cname + '='。 var ca = document.cookie.split(’;’);//使用分號(hào)來(lái)分割 document.cookie 字符串,并將分割后的字符串?dāng)?shù)組賦值給 ca (ca = document.cookie.split(’;’))。 //循環(huán) ca 數(shù)組 (i=0;i<ca.length;i++),然后讀取數(shù)組中的每個(gè)值,并去除前后空格 (c=ca[i].trim())。 for(var i=0; i<ca.length; i++) { var c = ca[i].trim(); if (c.indexOf(name)==0) return c.substring(name.length,c.length);//如果找到 cookie(c.indexOf(name) == 0),返回 cookie 的值 (c.substring(name.length,c.length)。 } return '';//如果沒(méi)有找到 cookie, 返回 ''。 } 檢測(cè) cookie 值的函數(shù)
最后,我們可以創(chuàng)建一個(gè)檢測(cè) cookie 是否創(chuàng)建的函數(shù)。
如果設(shè)置了 cookie,將顯示一個(gè)問(wèn)候信息。
如果沒(méi)有設(shè)置 cookie,將會(huì)顯示一個(gè)彈窗用于詢問(wèn)訪問(wèn)者的名字,并調(diào)用 setCookie 函數(shù)將訪問(wèn)者的名字存儲(chǔ) 365 天:
function checkCookie() { var username=getCookie('username'); if (username!='') { alert('Welcome again ' + username); } else { username = prompt('Please enter your name:',''); if (username!='' && username!=null) { setCookie('username',username,365); } } }
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專(zhuān)題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章:
1. jsp實(shí)現(xiàn)登錄驗(yàn)證的過(guò)濾器2. Xml簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理3. phpstudy apache開(kāi)啟ssi使用詳解4. ASP.NET MVC使用異步Action的方法5. 爬取今日頭條Ajax請(qǐng)求6. jsp文件下載功能實(shí)現(xiàn)代碼7. ajax實(shí)現(xiàn)頁(yè)面的局部加載8. uniapp解決軟鍵盤(pán)彈出問(wèn)題方法詳解9. uni-app結(jié)合.NET 7實(shí)現(xiàn)微信小程序訂閱消息推送10. AJAX的跨域問(wèn)題解決方案
