CSS word-break

一、CSS word-break的作用

CSS word-break屬性定義了在哪個點斷開連續的字符定義。該屬性可用於中文、日文和韓文等語言,同時也適用於其他語言如英語、法語等。

word-break 有兩種常用的屬性值。

.word-breek{
  word-break: break-all;
  word-break: keep-all;
}

break-all:表示允許字符串在單詞內斷開,在字符之後斷開,默認情況下,文本斷行規則在兩端是不允許斷詞的;

keep-all:表示不允許字符串在單詞中間斷開。只有在東亞的語言(CJK,即中文,日文,韓文)中使用這個值是有意義的。

二、word-break和中文排版的問題

在使用CSS排版中文的時候,我們通常會遇到以下問題:

中文字符長度比英文字符長度長,一個中文字符通常有2個英文字符那麼長;微軟雅黑等中文字體通常比博客英文字體長。這就導致了如果不特殊處理,排版結果就會出現中英混排的時候,出現一些難看、頓挫不流暢的字符間隔。

在這種情況下,word-break屬性就派上了用場。如果將word-break屬性設置為break-all,那麼在遇到中文字符之處,就會將整個字符單獨放一行顯示,從而解決了中英混排出現字符難看的問題。

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

三、其他用途

除了上述情況,word-break在其他方面也有許多用途。比如:

適用於單詞過長,溢出父容器,建議使用hyphens和word-break,之前我們學習了hyphens就是為了處理在中英文字混雜的文本中,單詞太長導致的單詞會溢出父容器的問題了,但是hyphens有一些局限性,word-break就能起到完美解決。在設置word-break為break-all的情況下,長單詞將被平均拆分,以適應帶有最小高度的容器。

.demo{
  width: 200px;
  word-break: break-all;
}

在英語、法語等語言中,我們知道連字符(-)常被用於單詞的分隔符。但是在中文、日語、韓語等語言中,連字符並不是常見的分隔符,那麼不加斷行會導致詞距與句子較大,使用 word-break 包括 break-all 和 keep-all 都可幫助實現連字正常排布。

.demo{
  width: 200px;
  word-break: break-all;
  text-align: justify;
  text-align-last: justify;
}

四、Word-break的兼容性

word-break為CSS3屬性,IE6-11和Safari 9以下的版本都不支持word-break: break-all

需要注意的是,在蘋果操作系統中,如果有OSX用戶自定義的等寬中文編碼存在,word-break: keep-all;將會失效且不能包裝空白。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/286548.html

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • at least one option must be selected

    問題解答:當我們需要用戶在一系列選項中選擇至少一項時,我們需要對用戶進行限制,即“at least one option must be selected”(至少選擇一項)。 一、…

    編程 2025-04-29
  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智能等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 銀行資金管理系統總結

    銀行資金管理系統是銀行日常業務運營的核心支撐系統,主要負責處理銀行的資金流動、結算、清算等業務。本文將從功能特點、技術架構、安全性以及未來發展趨勢等多個方面對銀行資金管理系統進行詳…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • 英語年齡用連字符號(Hyphenation for English Age)

    英語年齡通常使用連字符號表示,比如 “five-year-old boy”。本文將從多個方面探討英語年齡的連字符使用問題。 一、英語年齡的表達方式 英語中表…

    編程 2025-04-29