整合營(yíng)銷(xiāo)服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          CSS自動(dòng)換行、強(qiáng)制不換行、強(qiáng)制斷行、超出顯示省略號(hào)

          標(biāo)簽是默認(rèn)是自動(dòng)換行的,因此設(shè)置好寬度之后,能夠較好的實(shí)現(xiàn)效果,但是最近的項(xiàng)目中發(fā)現(xiàn),使用ajax加載數(shù)據(jù)之后,p標(biāo)簽內(nèi)的內(nèi)容沒(méi)有換行,導(dǎo)致布局錯(cuò)亂,于是嘗試著使用換行樣式,雖然解決了問(wèn)題,但是并沒(méi)有發(fā)現(xiàn)本質(zhì)原因,本質(zhì)在于,我當(dāng)時(shí)獲取的數(shù)據(jù)是一長(zhǎng)串的數(shù)字,瀏覽器應(yīng)該是對(duì)數(shù)字和英文單詞處理方式相近,不會(huì)截?cái)唷?

          先給出各種方式,再具體介紹每一個(gè)屬性。

          強(qiáng)制不換行

          p { white-space:nowrap; }

          自動(dòng)換行

          p { word-wrap:break-word; }

          強(qiáng)制英文單詞斷行

          p { word-break:break-all; }

          *注意:設(shè)置強(qiáng)制將英文單詞斷行,需要將行內(nèi)元素設(shè)置為塊級(jí)元素。

          超出顯示省略號(hào)

          p{text-overflow:ellipsis;overflow:hidden;}

          white-space: normal|pre|nowrap|pre-wrap|pre-line|inherit;

          white-space 屬性設(shè)置如何處理元素內(nèi)的空白

          normal 默認(rèn)。空白會(huì)被瀏覽器忽略。

          pre 空白會(huì)被瀏覽器保留。其行為方式類(lèi)似 HTML 中的 pre 標(biāo)簽。

          nowrap 文本不會(huì)換行,文本會(huì)在在同一行上繼續(xù),直到遇到 br 標(biāo)簽為止。

          pre-wrap 保留空白符序列,但是正常地進(jìn)行換行。

          pre-line 合并空白符序列,但是保留換行符。

          inherit 規(guī)定應(yīng)該從父元素繼承 white-space 屬性的值。

          word-wrap: normal|break-word;

          word-wrap 屬性用來(lái)標(biāo)明是否允許瀏覽器在單詞內(nèi)進(jìn)行斷句,這是為了防止當(dāng)一個(gè)字符串太長(zhǎng)而找不到它的自然斷句點(diǎn)時(shí)產(chǎn)生溢出現(xiàn)象。

          normal: 只在允許的斷字點(diǎn)換行(瀏覽器保持默認(rèn)處理)

          break-word:在長(zhǎng)單詞或URL地址內(nèi)部進(jìn)行換行

          word-break: normal|break-all|keep-all;

          word-break 屬性用來(lái)標(biāo)明怎么樣進(jìn)行單詞內(nèi)的斷句。

          normal:使用瀏覽器默認(rèn)的換行規(guī)則。

          break-all:允許再單詞內(nèi)換行

          keep-all:只能在半角空格或連字符處換行

          舉例看起區(qū)別:

          <!doctype html>

          <html lang="en">

          <head>

          <!--網(wǎng)站編碼格式,UTF-8 國(guó)際編碼,GBK或 gb2312 中文編碼-->

          <meta http-equiv="content-type" content="text/html;charset=utf-8" />

          <meta name="Keywords" content="關(guān)鍵詞一,關(guān)鍵詞二">

          <meta name="Description" content="網(wǎng)站描述內(nèi)容">

          <meta name="Author" content="Yvette Lau">

          <title>Document</title>

          <!--css js 文件的引入-->

          <style>

          .word{background:#E4FFE9;width:250px;margin:50px auto;padding:20px;font-family:"microsoft yahei";}

          /* 強(qiáng)制不換行 */

          .nowrap{white-space:nowrap;}

          /* 允許單詞內(nèi)斷句,首先會(huì)嘗試挪到下一行,看看下一行的寬度夠不夠,

          不夠的話就進(jìn)行單詞內(nèi)的斷句 */

          .breakword{word-wrap: break-word;}

          /* 斷句時(shí),不會(huì)把長(zhǎng)單詞挪到下一行,而是直接進(jìn)行單詞內(nèi)的斷句 */

          .breakAll{word-break:break-all;}

          /* 超出部分顯示省略號(hào) */

          .ellipsis{text-overflow:ellipsis;overflow:hidden;}

          </style>

          </head>

          <body>

          <div class = "word">

          <p class = "nowrap">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfs</p>

          <p class = "breakword">wordwrap:break-word;absavhsafhuafdfbjhfvsalguvfaihui</p>

          <p class = "breakAll">wordwrap:break-word;absavhsafhuafdfbjhfvsalguvfaihuivf</p>

          <p class = "normal">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfsa</p>

          <p class = "ellipsis">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfsab</p>

          </div>

          </body>

          </html>

          • 1
          • 2
          • 3
          • 4
          • 5
          • 6
          • 7
          • 8
          • 9
          • 10
          • 11
          • 12
          • 13
          • 14
          • 15
          • 16
          • 17
          • 18
          • 19
          • 20
          • 21
          • 22
          • 23
          • 24
          • 25
          • 26
          • 27
          • 28
          • 29
          • 30
          • 31
          • 32
          • 33

          效果如下:

          5代碼:

          <!doctype html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <meta name="viewport"
                    content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
              <meta http-equiv="X-UA-Compatible" content="ie=edge">
              <title>Document</title>
              <style>
                  p{
                      width: 200px;
                      background-color: #aaa;
                  }
                  .p1{
                      white-space: nowrap;
                  }
                  .p2{
                      word-wrap: break-word;
                  }
                  .p3{
                      word-break: break-all;
                  }
                  .p4{
                      white-space: nowrap;
                      overflow: hidden;
                      text-overflow: ellipsis;
                  }
              </style>
          </head>
          <body>
          <p class="p1">comrem dfgdsgfd sdffafsdafa dsfaf sdfsaf thgwer awdafqew</p>
          <p class="p2">ljj ljljoi hsgfa tgregv dsgrewg ygvsg werfwgr rweg vcdgss</p>
          <p class="p3">comrem dfgdsgfd sdffafsdafa dsfaf sdfsaf thgwer awdafqew</p>
          <p class="p4">comrem dfgdsgfd sdffafsdafa dsfaf sdfsaf thgwer awdafqew dgadsfs</p>
          </body>
          </html>


          1. 強(qiáng)制不換行:white-space 屬性是用來(lái)設(shè)置如何處理元素中的空白;

          屬性:

          • normal 默認(rèn)??瞻讜?huì)被瀏覽器忽略。
          • pre 空白會(huì)被瀏覽器保留。其行為方式類(lèi)似 HTML 中的 pre 標(biāo)簽。
          • nowrap 文本不會(huì)換行,文本會(huì)在在同一行上繼續(xù),直到遇到 br 標(biāo)簽為止。
          • pre-wrap 保留空白符序列,但是正常地進(jìn)行換行。
          • pre-line 合并空白符序列,但是保留換行符。
          • inherit 規(guī)定應(yīng)該從父元素繼承 white-space 屬性的值。
          p{  white-space: nowrap;}


          2、自動(dòng)換行:word-wrap屬性用來(lái)標(biāo)明是否允許瀏覽器在單詞內(nèi)進(jìn)行斷句,這是為了防止當(dāng)一個(gè)字符串太長(zhǎng)而找不到它的自然斷句點(diǎn)時(shí)產(chǎn)生溢出現(xiàn)象;

          屬性:

          • normal: 只在允許的斷字點(diǎn)換行(瀏覽器保持默認(rèn)處理)
          • break-word:在長(zhǎng)單詞或URL地址內(nèi)部進(jìn)行換行
          p{  word-wrap: break-word;}


          3、強(qiáng)制斷行:word-break 屬性用來(lái)標(biāo)明怎么樣進(jìn)行單詞內(nèi)的斷句;

          屬性:

          • normal:使用瀏覽器默認(rèn)的換行規(guī)則。
          • break-all:允許在單詞內(nèi)換行
          • keep-all:只能在半角空格或連字符處換行
          p{  word-break: break-all;}


          4、溢出顯示省略號(hào):ext-overflow CSS 屬性確定如何向用戶發(fā)出未顯示的溢出內(nèi)容信號(hào)。它可以被剪切,顯示一個(gè)省略號(hào)(’…’,U + 2026 HORIZONTAL ELLIPSIS)或顯示一個(gè)自定義字符串;

          • 屬性:clip這個(gè)關(guān)鍵字的意思是"在內(nèi)容區(qū)域的極限處截?cái)辔谋?#34;,因此在字符的中間可能會(huì)發(fā)生截?cái)?。為了能在兩個(gè)字符過(guò)渡處截?cái)?,你必須使用一個(gè)空字符串值 (’’)(To truncate at the transition between two characters, the empty string value (’’) must be used.)。此為默認(rèn)值。
          • ellipsis這個(gè)關(guān)鍵字的意思是“用一個(gè)省略號(hào) (’…’, U+2026 HORIZONTAL ELLIPSIS)來(lái)表示被截?cái)嗟奈谋尽薄_@個(gè)省略號(hào)被添加在內(nèi)容區(qū)域中,因此會(huì)減少顯示的文本。如果空間太小到連省略號(hào)都容納不下,那么這個(gè)省略號(hào)也會(huì)被截?cái)唷?/li>
          • string用來(lái)表示被截?cái)嗟奈谋尽W址畠?nèi)容將被添加在內(nèi)容區(qū)域中,所以會(huì)減少顯示出的文本。如果空間太小到連省略號(hào)都容納不下,那么這個(gè)字符串也會(huì)被截?cái)唷?/li>
          p{ overflow: hidden; text-overflow: ellipsis;}

          HTML標(biāo)簽相關(guān)的字符串格式化

          string nl2br ( string $string )

          nl2br() 就是將\n 替換成 <br> //javascript對(duì)\n才能夠執(zhí)行換行,對(duì)</br>是不能執(zhí)行換行

          htmlspecialchars() 把一些預(yù)定義的字符轉(zhuǎn)換為 HTML 實(shí)體。

          string htmlspecialchars(string,quotestyle,[character-set])

          轉(zhuǎn)換以下字符及對(duì)應(yīng)的實(shí)體

          & (和號(hào)) 成為 &
          " (雙引號(hào)) 成為 "
          ' (單引號(hào)) 成為 '
          < (小于) 成為 <
          > (大于) 成為 >

          第二個(gè)參數(shù): ENT_COMPAT 只轉(zhuǎn)換雙引號(hào), 保留單引號(hào), 為默認(rèn)值 compat: 兼容性

          ENT_QUOTES 同時(shí)轉(zhuǎn)換兩種引號(hào) quotes: 引號(hào)

          ENT_NOQUOTES 不對(duì)引號(hào)進(jìn)行轉(zhuǎn)換

          <html>
          <body>
          <?php
          $str = "John & \" 'Adams'";
          echo htmlspecialchars($str, ENT_COMPAT);
          echo "<br />";
          echo htmlspecialchars($str, ENT_QUOTES);
          echo "<br />";
          echo htmlspecialchars($str, ENT_NOQUOTES);
          ?>
          </body>
          </html>

          輸出結(jié)果:John & " 'Adams'

          John & " 'Adams'

          John & " 'Adams'

          htmlentities() 可以將所有的非ASCII碼字符轉(zhuǎn)換為對(duì)應(yīng)的實(shí)體代碼;除字母、數(shù)字、\外, 漢字和鍵盤(pán)上其他字符都轉(zhuǎn)換

          <?php
          $str = "A 'quote' \" is <b>bold</b>" ;
          echo htmlentities ( $str ); // 輸出后源代碼: A 'quote' is <b>bold</b>
          echo htmlentities ( $str , ENT_QUOTES ); // 輸出后源代碼: A 'quote' is <b>bold</b>
          ?>

          返回的結(jié)果:A 'quote' "is <b>bold</b>

          A 'quote' "is <b>bold</b>

          注意: htmlspecialchars()和htmlentities作用直接輸出HTML腳本

          htmlspecialchars()和htmlentities()函數(shù)對(duì)于轉(zhuǎn)義字符"\"處理,不會(huì)轉(zhuǎn)義實(shí)體代碼,要么當(dāng)轉(zhuǎn)義字符對(duì)待,要么原樣輸出;

          PHP中htmlentities和htmlspecialchars的區(qū)別

          這兩個(gè)函數(shù)的功能都是轉(zhuǎn)換字符為HTML字符編碼, 特別是url和代碼字符串。防止字符標(biāo)記被瀏覽器執(zhí)行。

          使用中文時(shí)沒(méi)什么區(qū)別, 但htmlentities會(huì)格式化中文字符使得中文輸入是亂碼。

          htmlentities轉(zhuǎn)換所有的html標(biāo)記, htmlspecialchars只格式化& ' " < 和 > 這幾個(gè)特殊符號(hào)

          addslashes() 在指定的預(yù)定義字符前添加反斜杠。

          這些預(yù)定義字符是:?jiǎn)我?hào) (') 雙引號(hào) (") 反斜杠 (\) NULL字符(\x00)

          提示:該函數(shù)可用于為存儲(chǔ)在數(shù)據(jù)庫(kù)中的字符串以及數(shù)據(jù)庫(kù)查詢語(yǔ)句準(zhǔn)備合適的字符串。

          注釋:默認(rèn)情況下,PHP 指令 magic_quotes_gpc 為 on,對(duì)所有的 GET、POST 和 COOKIE數(shù)據(jù)自動(dòng)運(yùn)行 addslashes()。

          不要對(duì)已經(jīng)被magic_quotes_gpc轉(zhuǎn)義過(guò)的字符串使用 addslashes(),因?yàn)檫@樣會(huì)導(dǎo)致雙層轉(zhuǎn)義。

          遇到這種情況時(shí)可以使用函數(shù) get_magic_quotes_gpc() 進(jìn)行檢測(cè)。(如:$c=(!get_magic_quotes_gpc())?addslashes($c):$c;)

          在本例中,我們要向字符串中的預(yù)定義字符添加反斜杠:

          <?php
          $str = "Who's John Adams?";
          echo $str . " This is not safe in a database query.<br />";
          echo addslashes($str) . " This is safe in a database query.";
          ?>

          輸出:

          Who's John Adams? This is not safe in a database query.

          Who\'s John Adams? This is safe in a database query.

          <?php
          header("Content-type:text/html; charset=utf-8");
          $str = "wo are \x0a studying \x00 php";
          echo $str;
          echo "<br>";
          echo addslashes($str);
          ?>

          輸出:

          wo are studying php

          wo are studying >wo are studying \0 php< php



          stripslashes() 刪除反斜線("\")

          在提交的表單數(shù)據(jù)中 ' " \ 等字符前被自動(dòng)加上一個(gè)\ ,這是配置文件php.ini中選項(xiàng)magic_quotes_gpc在起作用,

          默認(rèn)是打開(kāi)的,如果不處理則將數(shù)據(jù)保存到數(shù)據(jù)庫(kù)時(shí),有可能會(huì)被數(shù)據(jù)庫(kù)誤當(dāng)成控制符號(hào)而引起錯(cuò)誤。

          通常htmlspecialchars()和stripslashes()函數(shù)復(fù)合的方式,聯(lián)合處理表單中的提交的數(shù)據(jù)htmlspecialchars(stripslashes())

          strip_tags()

          string strip_tags ( string $str [, string $allowable_tags ] )

          剝?nèi)?HTML、XML 以及 PHP 的標(biāo)簽。

          <?php
          echo strip_tags("Hello <b><i>world!</i></b>","<b>");
          ?>

          輸出結(jié)果:Hello world!

          實(shí)例:

          <?php
          $str = "<b>webserver;</b> & \ 'Linux' & Apache";
          echo "$str"; //直接輸出
          echo "<br/>";
          echo htmlspecialchars($str,ENT_COMPAT); //只轉(zhuǎn)換雙引號(hào),為默認(rèn)參數(shù)
          echo "<br />";
          echo htmlspecialchars($str,ENT_NOQUOTES); //不對(duì)引號(hào)進(jìn)行轉(zhuǎn)換
          echo "<br />";
          echo htmlspecialchars($str,ENT_QUOTES); //同時(shí)轉(zhuǎn)換單引號(hào)和雙引號(hào)
          echo "<br />";
          echo htmlentities($str); //將所有的非ASCII碼字符轉(zhuǎn)換為對(duì)應(yīng)的實(shí)體代碼
          echo "<br />";
          echo addslashes($str); //將" ' \ 字符前添加反斜線
          echo "<br />";
          echo stripslashes($str); //刪除反斜線
          echo "<br />";
          echo strip_tags($str); //刪除<html>標(biāo)記
          ?>

          輸出結(jié)果:

          webserver; & \ 'Linux' & Apache


          主站蜘蛛池模板: 久久久av波多野一区二区| 一区视频免费观看| 亚洲欧美日韩中文字幕在线一区| 国产精品视频一区二区三区无码 | 波多野结衣一区二区三区aV高清| 久久精品综合一区二区三区| 国产伦精品一区二区三区不卡| 国产在线精品一区免费香蕉| 国产一区二区三区樱花动漫| 亚洲av永久无码一区二区三区| 2021国产精品一区二区在线| 韩国理伦片一区二区三区在线播放 | 美女视频免费看一区二区| 国产日韩视频一区| 伊人久久大香线蕉av一区| 日韩精品中文字幕无码一区| 毛片一区二区三区无码| 无码欧精品亚洲日韩一区夜夜嗨| 好看的电影网站亚洲一区| 亚洲熟女www一区二区三区| 精品一区二区三区免费视频| 无码囯产精品一区二区免费| 人妻精品无码一区二区三区| 狠狠爱无码一区二区三区| 久久精品国产一区二区三区 | 少妇精品久久久一区二区三区| 亚洲av乱码一区二区三区| 男人的天堂亚洲一区二区三区| 激情一区二区三区| 欧洲无码一区二区三区在线观看| 精品一区二区三区色花堂| 久久精品一区二区国产| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 国产一区二区三区精品视频| 色国产精品一区在线观看| 一区二区三区无码高清| 中文字幕AV一区二区三区 | 人妻少妇精品视频一区二区三区| 日韩精品电影一区| 一区二区在线观看视频| 人妻体内射精一区二区|