国产女主播成人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ù):4448

文本的排版根據(jù)言語的不同會(huì)有一些格局上的要求,比方簡(jiǎn)體中文中相似逗號(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)頁有寬度限制的,接連的超長(zhǎ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ì)顯示,卻使長(zhǎng)字符串換行。詳細(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精品久久99久久久久一-日韩三级a视频在线观看-国产精品99精品免费视频-日日夜夜有免费视频观看 | 日韩四级大黄片-在线人妻少妇一区二区三区-久久99五月天综合伊人-91狠狠综合久久久 | 久久亚洲一区视频-欧美日韩亚洲熟女第一页-成人免费91在线观看-成人三级网站在线观看 | 日韩国产欧美成人-日韩电影av手机在线观看-伊人中文字幕亚洲天堂-亚州av中文字幕 | 欧美日韩在线一区二区-91精品久久久久久综合五月天-亚洲熟女乱色一区二区三区丝袜-中文字幕久久精品亚洲乱码 | 91久久精品九色一区二区三区-国产精品久久久男同-亚洲国产久久久久久久久久久久-国产极品久久久久久久av电影 | 国产精品亚洲精品日韩已满十八小-丰满人妻一区二区三区免费看-91日韩中文字幕在线视频-年轻的母亲中文字幕在线看 | 日韩av欧美一区-日本久久综合久久-好好干天天日狠狠操-日本久久精品久久 | 精品人妻人妻人一区二区有限公司-精品午夜中文字幕熟女人妻在线-不卡视频一区二区免费看-69精品人妻久久久久久久久久久 | 午夜中文字幕人妻-欧美日韩午夜激情在线-日韩欧美怼大逼逼-精品久久久久久久一 | 日韩爱爱综合网-日韩av中文字幕免费在线播放-99热99色在线观看-97超碰三在线观看 | 97久久成人精品视频-久久久久久科技有限公司-蜜臀久久99最新合集-亚洲婷婷一区二区 | 亚洲av产在线精品日韩一页-国产成人91亚洲精品-日韩精品情色视频-久久久久久久久人妻一区精品 | 久久久人妻中文字幕-国产成人sm精品视频免费网站-欧美日韩国产一区自拍-国产成人精品午夜福 | 亚洲乱熟女一区二区三区91-国产成人精品自拍小视频-91久久久美女激情-乱色熟女综合一区二区三区 亚洲av嫩草极品在线观看-91久久人人夜色一区二区精品-美女视频图片一区二区三区-都市激情 校园春色 中文字幕 | 久久久极品一区二区-99精品人妻一区二区三蜜桃-亚洲av成人波多野一区二区三区-中文字幕人妻中出视频 | 久久国产精品天海翼av-96久久夜色精品国产-六月丁香天天色-日韩国产中文字幕有码 | 日韩大尺度av在线-成人av在线观看免费网址-久久免费视频观看99-日本精品免费一区二区三区 | 人妻少妇精品视频在线中文字幕-国产台湾黄色av一区二区-国产精品影视久久久久久久-久久99精品国产.久久久久久 | 久久人妻少妇嫩草av蜜桃-色婷婷国产精品综合网-久久久精品视频3-巨乳熟女少妇操色综合 | 日韩熟妇15p-日韩另类口味av网站-美日韩在线播放视频-1024久久精品国产 | 日本中文字幕v在线-日韩手机午夜av专区-超碰人妻福利20-亚洲天堂熟女av电影 | 人人添人人爽欧美一区二区-六月激情五月激情开心综合-国产蜜臀一区二区三区在线观看-日韩免费激情在线视频 | 国产成人av男人的天堂-人妻激情偷乱视频一区二区三区美女-国产又大又猛又黄的视频-91超碰pron在线观看 | 风间中文字幕一区二区-亚洲精品自拍第三页-亚洲影院久久久av天天-久久久999免费精品视频 | 日韩激情欧美激情-国产 日韩 欧美 综合-激情五月天最新视频网址-欧美精选一区二区三区四区 | 色婷婷狠狠18禁,车-国产日韩人妻久久-色综合久久久中文字幕精品1色婷婷-熟女天天插天天射天天操熟女 | 国产精品a62v久久久久久-国产成人自拍视频免费在线观看-欧美激情图片一区二区-精品区二区三区在线观看 | 日韩美女免费视频啪-17c视频在线观看一区二区-久热这里只有精品9-18岁日韩内射颜射午夜久久成人 9久久婷婷国产综合精品性色-日韩日韩日韩日韩日韩日韩av-99久久亚洲精品婷婷-日韩激情中文字幕视频 | 国产伦精一品二品三品app-亚洲人妻av在线电影-日韩av人妻在线-激情人妻文学污污 | 久久久亚洲熟妇一区二区三区-久久视频在线观看一区-国产二区中文字幕在线观看-91精选一区二区三区 | 91久久亚洲激情-超碰人妻福利精品-婷婷欧美一区二区-国产精品久久久久久久久久久免费 | 国产精品美女自视频-91久久久久久精品国产网站-韩国av不卡在线看-日韩一区在线观看二区三区在线观看 | 久久99电影精品欧美一级-欧美日韩经典一区二区三区在线观看-蜜臀av国内免费精品久久久夜夜-av中文字幕免费在线看 | 日韩一二三区av在线-日韩人妻熟女在线中文一区-免费在线观看中文字幕av-日韩欧美p片内射 | 97碰碰免费公开视频-中文字幕在线三级视频-999久热这里只有精品-91成人精品在线一区二区三区 | 91福利体验区试看30秒-国产一区二区免费在线视频-久久综合色天天久久综合图片-久久久精品免费少妇 | 亚洲bt欧美bt高清-亚洲国产欧美日韩一区二区三区-91精品国产综合久久久性色-国产精品久久久久久久va果冻 | 日本人妻精品久久久-天天干bb夜夜操bb-成人精品一区二区三区校园激情-91精品国产综合久久久久白拍 | 精品久久久久女人-国产人妻av日韩精品-激情五月激情五月激情五月-久久久久久久久性生活 | 成人乱码一区二区三区av日韩-狠狠久久久久人妻麻豆-日韩 欧美 精品 在线-91精品国产综合久久久久久粉嫩 |