首页 > 其他分享 >CSS文字超出宽度---换行总结

CSS文字超出宽度---换行总结

时间:2023-07-04 11:56:37浏览次数:50  
标签:break word space 换行 --- overflow white CSS

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            padding: 20px;
        }


        .parent {
            width: 100px;
        }


        .child1 {
            background-color: #a1cef5;
            line-height: 30px;
            padding: 20px;
        }


        .bgc_blue {
            background-color: #a1cef5;
        }


        .bgc_purple {
            background-color: #dca1f5;
        }


        .my_usually {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }


        .my_usually1 {
            white-space: nowrap;
            overflow: hidden;
        }


        /* 强制不换行 */
        .nowrap {
            white-space: nowrap;
        }


        /* 允许单词内断句,首先会尝试挪到下一行,看看下一行的宽度够不够,不够的话就进行单词内的断句 */
        .breakword {
            word-wrap: break-word;
        }


        /* 断句时,不会把长单词挪到下一行,而是直接进行单词内的断句 */
        .breakAll {
            word-break: break-all;
        }


        /* 超出部分显示省略号 */
        .ellipsis {
            text-overflow: ellipsis;
            overflow: hidden;
        }
    </style>
</head>


<body>


    <h1>使用样式控制字体换行下</h1>
    <div class="my_usually"> </div>
    <div class="parent">
        <h2 class="nowrap">第1种:white-space: nowrap; overflow: hidden; text-overflow: ellipsis;</h2>
        <p class="my_usually bgc_blue">white-space: nowrap; ---overflow: hidden; text-overflow: ellipsis;</p>


        <h2 class="nowrap">第2种:white-space: nowrap; overflow: hidden; </h2>
        <p class="my_usually1 bgc_blue">white-space: nowrap; ---overflow: hidden; </p>


        <h2 class="nowrap">第3种:white-space: nowrap; </h2>
        <p class="nowrap bgc_purple">white-space: nowrap;----absavhsafhuafdfbjhfvsalguvfaihuivfs</p>


        <h2 class="nowrap">第4种:word-wrap: break-word; </h2>
        <p class="breakword bgc_blue">word-wrap: break-word;----absavhsafhuafdfbjhfvsalguvfaihui</p>
        <h2 class="nowrap">第5种:word-break: break-all; </h2>
        <p class="breakAll bgc_purple">word-break: break-all;----absavhsafhuafdfbjhfvsalguvfaihuivf</p>
        <h2 class="nowrap">第6种:wordwrap:breakword; </h2>
        <p class="normal bgc_blue">wordwrap:breakword;----absavhsafhuafdfbjhfvsalguvfaihuivfsa</p>
        <h2 class="nowrap">第7种:text-overflow: ellipsis; overflow: hidden; </h2>
        <p class="ellipsis bgc_purple">text-overflow: ellipsis; overflow:
            hidden;----absavhsafhuafdfbjhfvsalguvfaihuivfsab</p>
    </div>


    <h1 class="my_h1">非使用样式控制字体换行下</h1>
    <div class="parent">
        <h3>汉字文字</h3>
        <div class="child1">普通情况普通情况下普通情况下普通情况下普通情况下普通情况下下</div>
        <h3>纯数字</h3>
        <div class="child1">2222222222222222222222222222222222222222</div>
        <h3>数字加文字加其他</h3>
        <div class="child1">33333333333333333333普通情况3333333普通情况333333333333333333333333333333</div>
        <h3>特殊符号加文字加其他</h3>
        <div class="child1">————————————______普通情况3333333普通情况333333333333333333333333333333</div>
    </div>
</body>


</html>

多行文字自动换行居中–实测好用的很OK

 

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .outDiv {
      border: 1px solid black;
      width: 200px;
      height: 200px;
      text-align: center;
      overflow: hidden;
    }

    .outDiv .innerDiv1 {
      display: inline-block;
      vertical-align: middle;
    }

    .outDiv .innerDiv-fix {
      display: inline-block;
      width: 0;
      height: 100%;
      line-height: 100%;
      vertical-align: middle;
      visibility: hidden;
    }
  </style>
</head>

<body>
  <div class="outDiv">
    <span class="innerDiv1">多行文字自动多行文字自动换行居中多行文字自动换行居中多行文字自动换行居中多行文字自动换行居中换行居中</span><span class="innerDiv-fix"><!-- 此标签不能换行 --></span>
  </div>
</body>

</html>

 

 

以下转载自https://www.cnblogs.com/dtdxrk/

word-break:break-all单词截断自动换行
word-break:break-all 例如div宽200px,它的内容就会到200px自动换行,如果该行末端有个英文单词很长(congratulation等),它会把单词截断,变成该行末端为conra(congratulation的前端部分),下一行为tulation(conguatulation)的后端部分了。

支持版本:IE5以上 该行为与亚洲语言的 normal 相同。也允许非亚洲语言文本行的任意字内断开。该值适合包含一些非亚洲文本的亚洲文本。

语法:word-break : normal | break-all | keep-all

normal : 依照亚洲语言和非亚洲语言的文本规则,允许在字内换行

break-all : 该行为与亚洲语言的normal相同。也允许非亚洲语言文本行的任意字内断开。该值适合包含一些非亚洲文本的亚洲文本

keep-all : 与所有非亚洲语言的normal相同。对于中文,韩文,日文,不允许字断开。适合包含少量亚洲文本的非亚洲文本

word-wrap:break-word单词不截断自动换行
word-wrap:break-word 例子与上面一样,但区别就是它会把congratulation整个单词看成一个整体,如果该行末端宽度不够显示整个单词,它会自动把整个单词放到下一行,而不会把单词截断掉的。

支持版本:IE5.5以上 内容将在边界内换行。如果需要,词内换行( word-break )也将发生。表格自动换行,避免撑开。

语法: word-wrap : normal | break-word

normal : 允许内容顶开指定的容器边界

break-word : 内容将在边界内换行。如果需要,词内换行(word-break)也行发生说明:设置或检索当当前行超过指定容器的边界时是否断开转行。

CSS强制性换行
一般情况下,元素拥有默认的

white-space:normal 自动换行

PS:不换行是white-space:nowrap

当录入的文字超过定义的宽度后会自动换行,但当录入的数据是一堆没有空格的字符或字母或数字(常规数据应该不会有吧,但有些测试人员是会这样子做的),超过容器宽度时就会把容器撑大,不换行。

解决方法(以IE,chrome,FF为测试浏览器):

{

word-break:break-all; /支持IE,chrome,FF不支持/

word-wrap:break-word;/支持IE,chrome,FF/

}

建议:word-break 用3C检测会显示问题的,导致百度快照也会出问题-这个属性OPERA FIREFOX 浏览器也不支持 word-break属性可以用white-space:normal;来代替,这样在FireFox和IE下就都能正确换行,而且要注意,单词间的空格不能用 来代替,不然不能正确换行。

text-overflow省略号…样式语法结构
text-overflow语法:
text-overflow : clip | ellipsis

clip :  不显示省略标记(…),而是简单的裁切
ellipsis :  当对象内文本溢出时显示省略标记(…)

display:block;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;

  

标签:break,word,space,换行,---,overflow,white,CSS
From: https://www.cnblogs.com/shuihanxiao/p/17525378.html

相关文章

  • 可视化容器管理工具-portainer.io使用
    续docker日常使用指南背景当我们开始使用docker后,我们的机器上镜像和容器会越来越多,或者有时候我们有多台开发机的时候,单纯使用命令行去管理镜像和容器就变得麻烦了,这时,我们就可以选择一些可视化的容器管理工具来保护我们为数不多的头发了。portainer.io就是这方面的一个不错的......
  • 16-1 文件处理三剑客置awk基本用法 16-2()16-3()
    一、awk BEGIN[root@centos8~]#awk'BEGIN{print"hello,awk"}'[root@centos8~]#awk-F:'{print$1":"$3}'/etc/passwd[root@centos8~]#df|awk-F"[[:space:]]+|%"'{print$5}'|sort-nr|head-n......
  • Netty-LengthFieldBasedFrameDecoder-解决拆包粘包问题的解码器
    LengthFieldBasedFrameDecoder的构造器参数中包括:maxFrameLength:指定解码器所能处理的数据包的最大长度,超过该长度则抛出TooLongFrameException异常。lengthFieldOffset:指定长度字段的起始位置。lengthFieldLength:指定长度字段的长度。lengthAdjustment:指定长度字段所表示......
  • 第009课 gcc和arm-linux-gcc和Makefile
    第001节_gcc编译器1_gcc常用选项__gcc编译过程详解gcc的使用方法gcc[选项]文件名gcc常用选项选项功能-v查看gcc编译器的版本,显示gcc执行时的详细过程-o指定输出文件名为file,这个名称不能跟源文件名同名-E只预处理,不会编译、汇编、链接t-S只编译,不会汇编、链接-c编译和汇编,不会链......
  • 使用 node 17以上版本运行项目报错--Error: error:0308010C:digital envelope routine
    一、起因#由于电脑重装系统,重新下载nodejs,自然更新到最新版本18,之前的版本才16。更新到最新nodejs版本后,运行vue文件,报错:this[kHandle]=new_Hash(algorithm,xofLen);^Error:error:0308010C:digitalenveloperoutines::unsupported   二、探索......
  • go-zero 源码——syncx/limit
    rtfsc:readthefuckingsourcecode以下为源码注释:packagesyncximport( "errors" "github.com/zeromicro/go-zero/core/lang")/***[rtfsc]*主题:limit.go*摘要:类似信号量*功能:用于控制数量,如并发数*[end]*///ErrLimitReturnindicatestha......
  • nacos-sdk-go/v2版本 提示客户端连接不上
    nacos-sdk-gov2报错提示客户端连接不上标签(空格分隔):nacos前言nacos版本:v2nacos-sdk-go版本:v2背景:使用nacos-sdk-go来获取配置,发现一直在找缓存目录的文件,但使用openapi可以获取到配置报错信息clientnotconnected,currentstatus:STARTING提示客户端连接失败???1999-0......
  • 2023-07-04 如何处理vue中不能监听到父传子组件props的变化
    前言:父传值给子组件,子组件需要根据传进来的值进行watch监听props中的值并遍历插入一个值,然后同时子组件的页面会跟着渲染。问题就是:子组件无法拿到watch更新的props值,比如传进一个list,然后通过watch来监听并在list里面加入一个新的值,前端页面拿不到新的值故而报错。原因:watch无......
  • 使用do-while分页调用接口
    使用场景远程请求接口,接口每次请求数据条数有限制,只能用分页多次调取再合并,需要使用总条数total和每次最大分页size去计算调用次数之前都是老实的使用取模取余来计算,,do-while会看起来优雅简单很多。代码示例List<Data>list=newArrayList<>();intpageNo=0;intpageS......
  • RNA-seq中的那些统计学问题
    <aname="data-preprocess"><h2>1.数据预处理[<sup>目录</sup>](#content)</h2></a><aname="filt-low-exp-genes"><h3>1.1.过滤低表达的基因[<sup>目录</sup>](#content)</h3></a>>......