這篇文章給大家分享的是有關(guān)JS如何實(shí)現(xiàn)判斷圖片是否加載完成的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),通許企業(yè)網(wǎng)站建設(shè),通許品牌網(wǎng)站建設(shè),網(wǎng)站定制,通許網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,通許網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。js有什么特點(diǎn)1、js屬于一種解釋性腳本語言;2、在絕大多數(shù)瀏覽器的支持下,js可以在多種平臺下運(yùn)行,擁有著跨平臺特性;3、js屬于一種弱類型腳本語言,對使用的數(shù)據(jù)類型未做出嚴(yán)格的要求,能夠進(jìn)行類型轉(zhuǎn)換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實(shí)現(xiàn)信息瀏覽或動態(tài)交互,從而有效地防止數(shù)據(jù)的丟失;5、基于對象的腳本語言,js不僅可以創(chuàng)建對象,也能使用現(xiàn)有的對象。
具體如下:
1、onload事件
<!DOCTYPE HTML> <html> <head> <title></title> </head> <body> <img src="images/background.png"> <p>loading...</p> <script type="text/javascript"> document.getElementsByTagName("img")[0].onload =function() { document.getElementsByTagName("p")[0].innerHTML ='加載完成!'; } </script> </body> </html>
2、complete屬性
<!DOCTYPE HTML> <html> <head> <title></title> </head> <body> <img src="images/background.png"> <p>loading...</p> <script type="text/javascript"> function imgLoad(img, callback) { var timer = setInterval(function() { if (img.complete) { callback(img); clearInterval(timer); } }, 50); } imgLoad(document.getElementsByTagName("img")[0], function() { document.getElementsByTagName("p")[0].innerHTML = '加載完成!'; }) </script> </body> </html>
3、onreadystatechange事件
<!DOCTYPE HTML> <html> <head> <title></title> </head> <body> <img src="images/background.png"> <p>loading...</p> <script type="text/javascript"> document.getElementsByTagName("img")[0].onreadystatechange = function() { if (this.readyState=="complete" || this.readyState=="loaded") document.getElementsByTagName("p")[0].innerHTML = '加載完成'; } </script> </body> </html>
注意:只有IE6-IE10支持onreadystatechange
事件,其它瀏覽器不支持。
4、onerror事件
網(wǎng)絡(luò)狀況不好或圖片不存在都可能觸發(fā)onerror
事件。
<!DOCTYPE HTML> <html> <head> <title></title> </head> <body> <img src="images/notExistImg.png"> <p>loading...</p> <script type="text/javascript"> document.getElementsByTagName("img")[0].onload =function() { document.getElementsByTagName("p")[0].innerHTML ='加載完成!'; } document.getElementsByTagName("img")[0].onerror =function() { document.getElementsByTagName("img")[0].src = "images/background.png"; } </script> </body> </html>
觸發(fā)onerror
事件后,會為img指定一個新的圖片。
問題:
新圖片存在則顯示新圖片,但若新圖片也不存在,則將繼續(xù)觸發(fā)onerror
,導(dǎo)致頁面循環(huán)跳動。
解決:
通過將onerror
置為null,來防止頁面循環(huán)跳動。
<!DOCTYPE HTML> <html> <head> <title></title> </head> <body> <img src="images/notExistImg.png"> <p>loading...</p> <script type="text/javascript"> document.getElementsByTagName("img")[0].onload =function() { document.getElementsByTagName("p")[0].innerHTML ='加載完成!'; } document.getElementsByTagName("img")[0].onerror =function() { document.getElementsByTagName("img")[0].src = "images/backgeound.png"; document.getElementsByTagName("img")[0].onerror = null; document.getElementsByTagName("p")[0].innerHTML ='加載失?。?#39;; } </script> </body> </html>
感謝各位的閱讀!關(guān)于“JS如何實(shí)現(xiàn)判斷圖片是否加載完成”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
新聞標(biāo)題:JS如何實(shí)現(xiàn)判斷圖片是否加載完成-創(chuàng)新互聯(lián)
文章來源:http://jinyejixie.com/article40/dcjieo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、ChatGPT、網(wǎng)站營銷、軟件開發(fā)、網(wǎng)站建設(shè)、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容