国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

javascript - 仿彈幕效果遇到的bug

瀏覽:146日期:2023-04-19 15:42:41

問題描述

利用定位寫的仿彈幕效果,一碰到邊緣就出現bug

CSS:

.dmMsg{ position:absolute; display: inline-block; right:0; top:0; color:#fff; font-size: 22px; font-weight: 700; text-align: center; line-height: 1em; z-index: 100;}

JS:

var $temp = $('<span class=’' + msgType + ' ' + moveInType + '’ data-count='+ msg_count +'>' + message + '</span>');$(’.’ + parent).append($temp); $temp.animate({’right’:’100%’ },15000,loop);}function loop(){ $temp.css(’right’,’-400px’); $temp.animate({’right’:’100%’ },15000,loop);}

問題是彈幕只要碰到屏幕左邊文字就折行了:javascript - 仿彈幕效果遇到的bug

但是輸入數字就不會這樣,我沒有給固定寬度,不知道為什么會這樣?javascript - 仿彈幕效果遇到的bug

問題解答

回答1:

這個和瀏覽器處理文本的原理有關,沒有深刨到底層,但是可以近似于這么理解:1、瀏覽器處理的區分標準其實是英文單詞,當遇到多個英文單詞(中間含空格分隔開才算,原因見下文)溢出屏幕時,猜測設計者的初衷是為了便于閱讀,所以瀏覽器會以空格作為分隔標準,對英文字母換行處理(因為瀏覽器認為空格隔開了,這是一個單詞),而長英文字母串,中間無空格,會被判斷為這是一整個單詞所以不會換行。2、輸入中文時,瀏覽器會把每一個中文判斷為一個“單詞”,所以對每一個溢出屏幕的字都進行了換行處理。3、對于數字,瀏覽器識別規則和英文字母一致。

所以綜上,并非是文字和數字有所區別,關鍵應該在于空格。例如你可以測試一下你代碼中的message = '777 777 777',即數字間含空格,會發現就算是數字,瀏覽器也換行了。同理亦可測試message = 'cat cat cat'和'catcatcat'的區別。最后回到white-space: nowrap這個屬性,w3school給出的含義是“文本不會換行,文本會在在同一行上繼續,直到遇到 <br> 標簽為止。”所以也能解釋得通為什么加上之后文字就沒有換行了。

回答2:

css加上white-space: nowrap;

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产一二三区精品 | 国内精品自产拍在线观看91 | 国产高清精品久久久久久久 | 久久影院国产 | 美国一级片在线观看 | 国产成人毛片精品不卡在线 | 亚洲国产精品激情在线观看 | 亚洲成a人片在线观看中文 亚洲成a人片在线观看中文!!! | 男女福利视频 | 国产伦一区二区三区四区久久 | 她也啪在线视频精品网站 | 久久精品视频一区 | 欧美片欧美日韩国产综合片 | 三级网站在线 | 成人精品一区二区www | 亚洲欧美精品网站在线观看 | 在线综合亚洲欧美自拍 | 东京一区二区三区高清视频 | 日本加勒比一区 | 92看片淫黄大片看国产片 | 毛片基地免费视频a | 国产精品亚洲综合久久 | 欧美一级毛片片aa视频 | 成人观看网站a | 国产一级毛片在线 | 97超频国产在线公开免费视频 | 国产综合在线视频 | 爱啪网亚洲第一福利网站 | 中美日韩在线网免费毛片视频 | 日韩国产精品欧美一区二区 | 在线观看日本亚洲一区 | 在线视频一区二区三区 | 91精品欧美成人 | 91人碰| 日韩中文字幕视频在线 | 国产精品日产三级在线观看 | 美女福利视频午夜在线 | 日韩中文字幕在线亚洲一区 | 中国女人真人一级毛片 | 欧美人成一本免费观看视频 | 亚洲综合在线视频 |