整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          HTML代碼中的空格和空行

          子1:(文本內容中的連續空格)

          <p>這段文本中,輸入連續的空格          大概輸入了十個。</p>

          顯示效果:“格”和“大” 之間的是個空格顯示出來只是一個空格。

          這段文本中,輸入連續的空格 大概輸入了十個。

          例子2:(代碼之間的連續空格)

          <span>span是一個行內標簽</span>               <span>和前面的span元素之間隔了很多個空格</span>

          顯示效果:兩個span元素之間連續的空格,顯示出來即"簽"與“和”之間的空格,只有一個空格。

          span是一個行內標簽 和前面的span元素之間隔了很多個空格

          上面兩個例子證明:HTML代碼中連續的空格在顯示時會顯示為一個空格,其余的多余的空格會被移除或者說被忽略。

          段落文本其實也是HTML代碼的一部分,只不過它在p標簽內部,而例子2的空格是在兩個span標簽之間。


          理解了空格,現在看看空行,同理

          例子3:(文本內容中的空行)

          <p>這段文本中,輸入連續的空行
          
          
          
          
          
          大概輸入了五行。</p>

          顯示效果:如我們所見,文本代碼中的五行空行,顯示出來也只是一個空格。

          這段文本中,輸入連續的空行 大概輸入了五行。

          例子4:(元素之間/標簽之間的空行),只要把例子2中的空格換成空行就可以了,顯示效果和例子2的一樣,多行空行都只會顯示為一個空格。

          <span>span是一個行內標簽</span>
          
          
          
          
          
          <span>和前面的span元素之間隔了很多空行</span>


          span是一個行內標簽 和前面的span元素之間隔了很多空行

          得證:HTML 代碼中的所有連續的空格或空行(換行)都會被顯示為一個空格。


          既然如此,如果我們希望擴大兩個字符之間的間距,讓代碼中的連續空格或空行顯示出來的結果也是連續的空格或空行,那該怎么辦?其實很簡單。

          方法一:我們可以用預格式化標簽<pre>,無論是空格或空行都適用。

          <pre>
          這是
          預格式文本。
          它保留了      空格
          和換行。
          </pre>

          顯示效果

          這是
          預格式文本。
          它保留了      空格
          和換行。


          方法二:我們可以用空格實體符 代替空格,用換行標簽<br/>代替空行。雖然這種方法可以得到我們想要的顯示效果,但是對搜索引擎不是最友好的方式,因為 和<br/>在HTML中都是沒有語義的。所以建議盡量少用。另外需要注意的是, 必須小寫,而且最后面的分號是不能省略的。


          方法三:(適合空格)使用全角空格

          全角空格被解釋為漢字,所以不會被被解釋為HTML分隔符,可以按照實際的空格數顯示。

          問題:怎么使用全角輸入法?

          以搜狗輸入法為例,我們通常使用的是半角輸入,其狀態欄中有個月亮的標志,就說明正在使用的是半角輸入,如果是太陽的標志,就說明使用的是全角輸入。全角/半角的切換可以通過點擊標志,也可以通過快捷鍵 Shift+Space(空格符)切換。

          半角輸入(月亮)

          全角輸入(太陽)

          方法四:使用CSS樣式中字間隔屬性控制,CSS中的word-spacing 屬性可以改變字(單詞)之間的標準間隔。我們知道英文中兩個單詞之間是通過空格隔開的,所以我們視覺上可以這樣認為,word-spacing改變了(拉長或縮短)單詞之間那個空格的寬度。

          方法五:使用CSS樣式中的white-space 屬性,這個屬性聲明如何處理元素內的空白符。

          描述

          normal

          默認。空白會被瀏覽器忽略。

          pre

          空白會被瀏覽器保留。其行為方式類似 HTML 中的 <pre> 標簽。

          nowrap

          文本不會換行,文本會在在同一行上繼續,直到遇到 <br> 標簽為止。

          pre-wrap

          保留空白符序列,但是正常地進行換行。

          pre-line

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


          white-space:normal;就是正常,和不設置一樣,連續空格和空行都只會顯示一個空格。

          white-space:nowrap;不換行是什么意思呢?正常情況下,當我們的文本超出了文本域,文本就會自動折行,這個設置就是說不自動折行了,而是碰到換行標簽<br />才換

          white-space:pre;和方法一相同,將文本原樣輸出顯示。當文本超出文本域時,不換行,會產生滾動條。

          white-space:pre-wrap;保留空格和空行,但當文本超出文本域時,會自動換行。

          white-space:pre-line;連續的空格會顯示為一個空格,但保留連續的空行。

          我們從網頁上抓取數據時,有時候會遇到數據被嵌套在HTML標簽里的情況,特別是當這些數據是以JSON格式呈現的時候。這些JSON字符串中可能含有許多不必要的空格,使得數據看起來很亂,不易于閱讀。

          在C#編程語言中,我們可以使用正則表達式來輕松地解決這個問題。通過匹配和替換HTML標簽以及連續的空格,我們可以使數據更加整潔,更易于處理。

          下面我們用一個具體的例子,說明如何使用C#和正則表達式來清理和處理這些嵌套在HTML中的JSON數據。

          假設我們有如下的HTML字符串,其中包含一個JSON數據段:

          優化JSON數據格式:使用C#正則表達式去除HTML標簽并替換多余空格

          我們的目標是提取出這個JSON數據段,去除其中的HTML標簽,并將多余的空格替換為單個空格,以便于閱讀和解析。

          首先,我們需要使用C#的正則表達式來提取出JSON數據段。正則表達式 @"<textarea[^>]*>((.|\n)*?)<\/textarea>"將匹配并提取出位于 <textarea> 和 </textarea> 標簽之間的所有內容。

          接下來,我們將使用另一個正則表達式 @"\s+" 來匹配一個或多個連續的空格,并將其替換為一個空格。

          下面是完成這些步驟的C#代碼示例:

          // 代碼注釋:

          // 此處運用正則表達式的強大功能,首先定位并剝離HTML標簽以提取純JSON文本;

          // 然后,針對JSON文本中的連續空白字符(包括空格、制表符等),使用另一個正則表達式進行查找和替換;

          // 最終輸出的formattedJsonString是經過整理、僅保留單個空格的格式化JSON字符串。

          現在,JSON字符串已經沒有多余的空格,格式整潔,易于閱讀。這樣的數據更便于后續的處理和解析。

          預格式化的文本:

          <pre>

          此例演示如何使用 pre 標簽

          對空行和 空格

          進行控制

          </pre>


          瀏覽器支持

          目前大多數瀏覽器支持 <pre> 標簽。


          標簽定義及使用說明

          <pre> 標簽可定義預格式化的文本。

          被包圍在 <pre> 標簽 元素中的文本通常會保留空格和換行符。而文本也會呈現為等寬字體。


          提示和注釋

          提示: <pre> 標簽的一個常見應用就是用來表示計算機的源代碼。


          在HTML 4.01 與 HTML5中的差異

          在 HTML 4.01 中,"width" 屬性已廢棄,不可使用。 HTML5 不支持"width"屬性。


          屬性

          屬性描述
          widthnumberHTML5 不支持該屬性。HTML 4.01 已廢棄該屬性。 定義每行的最大字符數(通常是 40、80 或 132)。

          全局屬性

          <pre> 標簽支持全局屬性,查看完整屬性表 HTML全局屬性。


          事件屬性

          <pre> 標簽支持所有 HTML事件屬性。

          如您還有不明白的可以在下面與我留言或是與我探討QQ群308855039,我們一起飛!


          主站蜘蛛池模板: 在线视频国产一区| 无码精品不卡一区二区三区| 精品一区二区三区无码免费直播| 精品免费国产一区二区| 日韩精品人妻一区二区中文八零| 国内国外日产一区二区| 亚洲视频一区二区三区四区| 国产福利在线观看一区二区| 亚洲一区二区三区无码影院| 亚洲一区二区三区精品视频| 久久久老熟女一区二区三区| 天天视频一区二区三区 | 免费看无码自慰一区二区| 国产精品无码一区二区三级| 麻豆一区二区免费播放网站| 另类免费视频一区二区在线观看| 人成精品视频三区二区一区| 一区二区三区在线免费观看视频| 精品国产aⅴ无码一区二区| 国模精品一区二区三区| 国产精品亚洲一区二区三区久久| 少妇激情av一区二区| 亚洲bt加勒比一区二区| 国产乱码精品一区二区三区中| 国产精品伦子一区二区三区| 高清国产AV一区二区三区| 日本成人一区二区三区| 国产成人高清精品一区二区三区| 在线中文字幕一区| 亚洲国产激情在线一区| 一区二区三区视频网站| 在线观看一区二区精品视频| 国产成人精品一区二区三区| 精品无码国产AV一区二区三区| 久久精品国产一区二区三区肥胖 | 日本一区二区不卡在线| 国产99久久精品一区二区| 曰韩人妻无码一区二区三区综合部| 无码少妇一区二区浪潮免费| 一区二区三区午夜| 国产成人av一区二区三区在线|