前言
最近在工作项目中接触到Web界面设计的问题,要实现文字两端对齐的效果。在网上搜索了一下,差不多都是互相转帖,用的都是类似的技巧:
text-align:justify;
text-justify:inter-ideograph;
参考
但问题是,我怎么就看不到效果呢?无论是英文还是中文,在IE和chrome下都不起作用。后来,终于在StackOverflow上找到解决方法了。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
.arter li {
font-size: 14px;
line-height: 24px;
color: #4a4a4a;
}
.arter span {
height: 24px;
line-height: 24px;
width: 65px;
text-align: justify;
display: inline-block;
overflow: hidden;
vertical-align: top;
}
.arter i {
display: inline-block;
width: 100%;
height: 0;
}
.arter1 li {
font-size: 14px;
line-height: 24px;
color: #4a4a4a;
}
.arter1 span {
height: 24px;
line-height: 24px;
width: 65px;
text-align: justify;
display: inline-block;
overflow: hidden;
vertical-align: top;
}
.arter1 span:after {
content: " ";
display: inline-block;
width: 100%;
height: 0px;
}
</style>
</head>
<body>
<ul class="arter">
<li><span>作品名称<i></i></span>: 宝贝儿</li>
<li><span>作品类型<i></i></span>: 油画</li>
<li><span>艺术家<i></i></span>: 张玉瀛</li>
<li><span>风格<i></i></span>: 超现实</li>
<li><span>材质<i></i></span>: 布面油画</li>
<li><span>题材<i></i></span>: 人物</li>
<li><span>创作时间<i></i></span>: 2011</li>
<li><span>所在位置<i></i></span>: 华东</li>
<li><span>尺寸<i></i></span>: 78x78cm</li>
</ul>
<br /><br />
<ul class="arter1">
<li><span>作品名称</span>: 宝贝儿</li>
<li><span>作品类型</span>: 油画</li>
<li><span>艺术家</span>: 张玉瀛</li>
<li><span>风格</span>: 超现实</li>
<li><span>材质</span>: 布面油画</li>
<li><span>题材</span>: 人物</li>
<li><span>创作时间</span>: 2011</li>
<li><span>所在位置</span>: 华东</li>
<li><span>尺寸</span>: 78x78cm</li>
</ul>
</body>
</html>
复制代码
效果预览
从效果图可以看到,除了要在块级元素加text-align:justify样式外,还需要在里面加一个空的span元素,并应用样式。另外,对于中文还必须用空格隔开汉字,否则也没有两端对齐的效果。英文每个单词都有空格隔开,所以没问题。
但是加入HTML元素又违反了结构表现分离的原则,我们可以改用after、before伪元素:
li:after {
content: " ";
display: inline-block;
width: 100%;
}
参考资料:css实现文字两端对齐