前端开发经验——html行内元素没有width(设置宽度无效)
分类:计算机 | 前端 | CSS | 综合 1266
更新:2021-05-30 21:26:15编辑
最近想实现这么一个效果,就是当元素中的文字长度超过元素指定长度时把多余的部分用省略号来表示,当鼠标放大元素上面时可以显示全部的文字信息,于是在网上找了一些实现方法,使用了如下css样式来实现:
html代码:
<div>
<span class="viewtitle" title="我是一串很长的文字,超过了指定的宽度后用省略号显示超出部分">
我是一串很长的文字,超过了指定的宽度后用省略号显示超出部分
</span>
</div>
css代码:
.viewtitle{
width:150px; /*设置div或者span的固定宽度*/
overflow:hidden; /*文字超出宽度部分隐藏*/
text-overflow:ellipsis; /*显示省略符号来代表被修剪的文本*/
white-space:nowrap; /*文本不会换行,文本会在在同一行上继续,直到遇到 <br> 标签为止*/
word-break:keep-all; /*只能在半角空格或连字符处换行*/
}
然后发现并没有达到我想要的效果,于是又上网查了一些资料,才搞清楚了,原来是html的行内元素,而html行内元素是没有宽高的!也就是说没有width,如果想要行内元素有宽高的话,可以将行内元素转化为块级元素或者行内块元素,就是加上如下代码即可:
display:block;(转为块元素,独占一行)
display:inline-block;(转为行内块元素,在一行内显示但又有宽高)
所以可以在上面css代码中加上display:block或者display:inline-block就可以实现我们想要的效果了,新的css代码如下:
.viewtitle{
display:inline-block; /*将span设置为行内块级元素,使其有宽度,这样下面设置的width才有效果*/
width:150px; /*设置div或者span的固定宽度*/
overflow:hidden; /*文字超出宽度部分隐藏*/
text-overflow:ellipsis; /*显示省略符号来代表被修剪的文本*/
white-space:nowrap; /*文本不会换行,文本会在在同一行上继续,直到遇到 <br> 标签为止*/
word-break:keep-all; /*只能在半角空格或连字符处换行*/
}
猿导航
阅读排行榜
- 1vue和el-table使用经验-如何刷新表格数据10950
- 2three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目9499
- 3Microsoft Visual C++ Redistributable是什么,有什么作用?7275
- 4mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)5844
- 5uni-app使用经验—vue页面和html页面如何互相调用接口并传参5484
- 6Intellij IDEA下的版本控制VCS的启用与关闭4900
- 7Spring学习经验—@ResponseBody注解的使用说明4894
- 8Druid异常解决经验—java.sql.SQLException url not set4514
- 9如何用批处理命令(bat脚本)启动和停止windows服务4284
- 10nuxt.js项目中如何添加和使用全局变量4158
- 11解决SpringBoot使用maven下载不了jar包的问题3499
- 12linux中解压tar.gz文件报错“gzip: stdin: invalid compressed data--format violated”3394
- 13nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数3247
- 14在Nuxt.js项目的head中引用外部js文件3089
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一3066