国产女主播成人av-亚洲国产精品黑人久久久-欧美日韩一区二区三区gif-91综合久久噜久久-国产日韩欧美在线观看大片-国产一区二区三区御姐-开心激情婷婷久久视频-亚洲精品日韩在线观看视频网站-亚洲av欧美av日韩av,日本色一区二区三区,国产亚洲成性色av人片在线观,国产91熟女高潮一区二区抖

歡迎來到合肥浪訊網(wǎng)絡(luò)科技有限公司官網(wǎng)
  咨詢服務(wù)熱線:400-099-8848

接連字符主動(dòng)換行的處理方案

發(fā)布時(shí)間:2019-06-04 文章來源:本站  瀏覽次數(shù):4446

文本的排版根據(jù)言語的不同會(huì)有一些格局上的要求,比方簡體中文中相似逗號(hào)、分號(hào)等標(biāo)點(diǎn)符號(hào)不會(huì)出現(xiàn)在一行的最初,對(duì)于英文來講就是一個(gè)完好單詞不會(huì)在兩行顯示,瀏覽器會(huì)根據(jù)相似這樣的準(zhǔn)則來顯示文本。但是因?yàn)榫W(wǎng)頁有寬度限制的,接連的超長的字母、數(shù)字或標(biāo)點(diǎn)符號(hào)超出其所在區(qū)域?qū)挾鹊南拗贫鴮?dǎo)致影響頁面視覺,如 例1 所示。這個(gè)問題在顯示用戶輸入信息時(shí)尤為突出,這兒就是要說如何處理這個(gè)問題。

在CSS3草案中,對(duì)文本的處理新增了兩個(gè)新特點(diǎn) word-wrap 和 word-break 來處理這個(gè)問題:

  1. {word-wrap:break-word;} :依照亞洲言語和非亞洲言語的文本規(guī)則,答應(yīng)在字內(nèi)換行,且答應(yīng)非亞洲言語文本行的恣意字內(nèi)斷開
  2. {word-break:break-all;} : 內(nèi)容將在邊界內(nèi)換行,如需要?jiǎng)t詞內(nèi)換行(word-break)也行發(fā)作

下面是常見瀏覽器的支撐狀況:

IE Firefox Opera Safari/Chrome
{word-wrap:break-word;} td元素需設(shè)置其寬度
見 例4 和 例5
不支撐 不支撐 不支撐td元素
見 例4 和 例5
{word-break:break-all;} 不支撐接連的符號(hào)
見例3
不支撐 不支撐 支撐

因?yàn)閧word-break:break-all;}導(dǎo)致英文和數(shù)字可讀性嚴(yán)重下降且無法使接連符號(hào)換行,所以{word-wrap:break-word;}是一個(gè)相對(duì)較好的選擇。

但面臨瀏覽器的如此糟糕支撐,所以不能不憑借JavaScript來處理這個(gè)問題,即當(dāng)瀏覽器不支撐CSS處理方案時(shí),在接連字符串的恰當(dāng)方位刺進(jìn)​字符(當(dāng)然還能夠用和-,這三個(gè)字符在瀏覽器中的支撐狀況請(qǐng)看ppk的《The wbr tag》),這些字符寫在瀏覽器中不會(huì)顯示,卻使長字符串換行。詳細(xì)完成代碼如下:

function fnBreakWordAll(o){
var o = o || {},
iWord = o.word || 13,
iRe = o.re || '[a-zA-Z0-9]',
bAll = o.all || false,
sClassName = o.className || 'word-break-all',
aEls = o.els || (function(){
var aEls = [],
aAllEls = document.getElementsByTagName('*'),
re = new RegExp('(?:^|\\s+)' + sClassName + '(?:\\s+|$)');
for(var i =0,iLen = aAllEls.length; i < iLen ; ++i){
if(re.test(aAllEls[i].className)){
aEls[aEls.length] = aAllEls[i];
}
}
return aEls;
})() || [],
fnBreakWord = function(oEl){
// 根據(jù)http://www.hedgerwow.com/360/dhtml/css-word-break.html修正
if(!oEl || oEl.nodeType !== 1){
return false;
}else if(oEl.currentStyle && typeof oEl.currentStyle.wordWrap==='string'){
breakWord = function(oEl){
oEl.runtimeStyle.wordWrap = 'break-word';
return true;
}
return breakWord(oEl);
}else if(document.createTreeWalker){
var trim = function (str) {
str = str.replace(/^\s\s*/, '');
var ws = /\s/,
i = str.length;
while (ws.test(str.charAt(--i)));
return str.slice(0, i + 1);
}
breakWord = function(oEl){
var dWalker=document.createTreeWalker(oEl,NodeFilter.SHOW_TEXT,null,false);
var node,s,c = String.fromCharCode('8203'),
//re = /([a-zA-Z0-9]{0,13})/;
re = new RegExp('('+ iRe +'{0,' + iWord + '})');
while (dWalker.nextNode()){
node = dWalker.currentNode;
s = trim(node.nodeValue).split(re).join(c);
node.nodeValue = s;
}
return true;
}
return breakWord(oEl);
}
};
for(var i=0,n=aEls.length; i  var sUa = navigator.userAgent,
sTn = aEls[i].tagName.toLowerCase() ;
if((/Opera/).test(sUa) || (/Firefox/).test(sUa) || ((/KHTML/).test(sUa) &&
(sTn === 'td' || sTn === 'th')) || bAll){
fnBreakWord(aEls[i]);
}
}
}

詳細(xì)使用請(qǐng)看 演示實(shí)例

fnWordBreakAll函數(shù)供給一些定制參數(shù),使用方法和參數(shù)含義如下:

fnWordBreakAll({word:15,re:'[\\w]',all:true});

參數(shù) 說明
word 正整數(shù),默許是13 在這個(gè)字?jǐn)?shù)內(nèi)的單詞不會(huì)被刺進(jìn)\u8203,印象中超越13個(gè)字母的單詞不多,這能夠確保絕大部分單詞不會(huì)被打碎
re 正則表達(dá)式,默許[a-zA-Z0-9] 單詞的正則表達(dá)式,用以確定一個(gè)單詞是哪些字符組成,留意\的轉(zhuǎn)義
all 布爾值,默許false 確定是否在所有的瀏覽器中履行,默許在Opera和Firefox,以及當(dāng)class使用在th或td的Safari上履行,這個(gè)主要用在.word-break-all沒有定義時(shí),會(huì)對(duì)IE加上款式
className 合法class名,默許word-break-all 履行函數(shù)的元素對(duì)應(yīng)特點(diǎn)名

這個(gè)函數(shù)的核心部分修正自Hedger Wang 整理了一個(gè)JavaScript處理方案《Cross Browser Word Breaker》,其使用 document.createTreeWalker 和 split 方法給非IE瀏覽器的每個(gè)字符間加入了 ,它用在純中文文本基本上沒有什么問題,但是如果你仔細(xì)觀察他給出的比如就會(huì)發(fā)現(xiàn)文本中有英文或數(shù)字時(shí),盡管處理了換行問題,但是使文本難以閱覽,且增大了字符間的距離,所以我在此基礎(chǔ)上做了上面的改進(jìn)

上一條:讀“規(guī)劃的3個(gè)C”之構(gòu)圖...

下一條:悟道web規(guī)范:前端功能...

99久久精品人妻一区二区三区-超碰在线视频免费97-在线免费观看在线免费观看av-精品日本一区二区三区免费 | 日韩高跟丝袜诱惑美腿黄片-美日韩成人xxxaaa视频-日韩人妻ntr-91综合精品国产丝袜长腿久久 | 久久久亚洲熟妇一区二区三区-久久视频在线观看一区-国产二区中文字幕在线观看-91精选一区二区三区 | 日韩人欧美?片内射久久-中文字幕精品在线人妻-av一区二区回娘家-日韩在线中文字幕伦理 | 在线视频中文字幕成人-久久精品人妻少妇一区-日韩黄色一级夫妻性生活录像1-伊人中文字幕亚洲 | 成人国产av精品免费网-99久热只有精品视频在线观看-久久青草线视频观看免费版在线看中文版-97日韩就爱高清视频 | 国产一区二区在线观看不卡-日韩av岛国在线观看-91极品尤物在线播放国产-性风俗店中文字幕在线视频 | 99久久国产丝袜-高清视频 一区二区三区四区-日韩欧美一区二区三区不卡-91精品久久久久久久久99蜜臂 | 国产免看一级a一片成人av-久久99精品久久久久久琪琪-久久中文字幕av-国产av一区二区三区四区最喜欢 | 69久久夜色精品国产69乱粉嫩-国产av一区二区大香蕉-人妻丰满日韩一区二区-国产激情四射完整视频 久99久视频精品免费观动漫-99精品视频只有精品高清77-国产成人鲁色资源国产91色综-国产午夜精品久久久久动 | 久久爱这里只有久久精品-久久久久中文字幕国产-欧美日韩av在线免费观看-av在线资源导航网 | 国产黄色小视频看看-久久大久久就久久精品欧美-日韩精品视频在线免费观看首页-国产麻豆精品视频网 | 国产日本欧美一区二区三区-国产精品久久久久777-国产日韩一区欧美-欧美日韩国产欧美日韩国产 | 久久99久久com-欧美久久久久久久久久人妻-内射人妻日韩中文字幕在线观看-另类h中文字幕 | 亚洲国产欧美在线人成aⅴ-国色天香精品二区三区-久日视频在线观看免费-91精品久久久久精品一区 | 人妻丰满熟妇乱又伦-黑人强壮的爱爱视频-欧美国产日韩一区二区三区-日韩精品五十熟 | 精品久久一区二区三区蜜桃-91在线视频观看不卡视频一区-精品久久久91av-日本精品一区,二区 | 国产中文字幕在线播放-99久久久怡红院蜜臀av-国产精品色婷婷久久-91人妻精品久久久久久久久熟妇 国产免费69成人精品视频-日本中文字幕一区二区三区高清-avi免费中文字幕-蜜桃臀久久久蜜桃臀 | 中文字幕av有码在线-日韩中文字幕视频了-婷婷激情亚洲五月天-亚洲人妻成人在线免费 | 1024手机看片欧美日韩-久久三级人妻熟妇-欧美日韩亚洲第六页-av日韩在线观看网站 | 丰满人妻精品一区二区在线-久久久艹视频在线观看-日韩av中文字幕手机在线观看-国产老熟女一区二区三区 | 99久久久免费精品国产-成人午夜aaaa片-成人国产一区在线观看-婷婷久久一婷婷 | 国产又大又长又粗又硬又黄又爽-五月天丁香花开网久久-高清不卡的一区二区三区视频-国产一区二区三区 中文字幕 | 日韩成人精品视频网站-国产h在线视频观看-国产又黄视频王者英雄-91精品一区二区更新 | 成人网激情视频日韩-日韩欧美亚洲一区二区-九九久久精品视频-91免费干逼视频 | av熟女一区二区三区蜜桃-亚洲中文字幕精品人妻-日产精品久久久久久久蜜桃-久久久久久国产少妇熟女 | 69精品少妇一区二区三区蜜桃-久久久亚洲人妻一区-色婷婷人妻av一区二区-色综合久久久久天堂 | 国产精品久久久久久成人-色婷婷综合久久久中文精品-日韩制服丝袜在线观看-亚洲精品女av | 91插插插免费观看-久久精品熟女人妻一区二区三区-国产91在线精品观看-69精品久久久久久久久久 | 久久婷婷色一区二区三-国产成人97精品免费看片-欧美黑人性猛视频-99久久免费观看少妇高潮 | 91婷婷韩国欧美一区二区-99精品色国产综合久久久蜜臀-日韩美女在线观看免费-亚洲综合婷婷久久十月 | 日韩激情短视频在线-99热精品视频免费在线观看-午夜精品久久久久久久久噜噜-日韩最近免费播放视频 | 91亚洲精品久久久久久久久-大香蕉久久一二三区-精品视频在线观看一区二区三区-亚洲欧美日韩图片网页 | 色婷婷日韩一区二区-亚洲精品国产成人av麻豆-中文字幕人妻丝袜成熟-欧美亚洲一区二区三区久久久 日韩欧美国产制服丝袜-18禁国产91精品久久久久久-久久综合色鬼色88-国产'av一区二区三区 | 久久热在线观看免费视频-国产精品99久久久久久夜夜嗨-欧美精品国产白浆久久久久-777色婷婷av一区二区三99 | 久久re这里只有精品99-岛国激情av一区二区三区-中文字幕熟女人妻丝袜-超碰亚洲精品91 | 国偷自产一区二区三区在线视频-日韩亚洲视频区-色婷婷中文字幕一区久久91-一本色道久久88综合亚洲精品密 | 久久韩国主播青草-日韩美亚洲av电影-国产精品成人三级网站-国精产品一区二区三区区别 | 久久五月婷婷之激情综合-国产乱子伦一区二区三区网-九九99久久精品少妇-91狠狠综合久久久久久精品 | 久久精品视频免费观看99-97欧美精品久久久久蜜桃-粉嫩av一区二区三区在线-久久人人爽人人av | 国产在线 一区二区-日韩美所有av电影-日韩美女主播在线一区-欧美日韩国产va另类 |