我需要将文本完全放入 100% 宽度的 div 容器中。
我尝试使用letter-spacing,但它看起来只接受 px/em,而不是百分比值.. 但这不会响应(例如调整窗口大小)。
这就是我得到的:http: //jsfiddle.net/3N6Ld/
我应该采取另一种方法吗?有任何想法吗?谢谢
我需要将文本完全放入 100% 宽度的 div 容器中。
我尝试使用letter-spacing,但它看起来只接受 px/em,而不是百分比值.. 但这不会响应(例如调整窗口大小)。
这就是我得到的:http: //jsfiddle.net/3N6Ld/
我应该采取另一种方法吗?有任何想法吗?谢谢
如果你知道你有多少个字母,你可以使用vw(视口宽度)单位来实现这一点。
在下面的示例中,我使用了 的值14.29vw,因为 100(窗口宽度的 100%)除以 7(单词“CONTENT”中的字母数)大约是 14.29。
html, body {
  margin: 0;
  height: 100%;
  width: 100%;
}
.container{
  background: tomato;
  height: 10%;
  width: 100%;
}
.content {
  color: white;
  letter-spacing: 14.29vw;
  overflow: hidden;
}
<div class="container">
  <div class="content">
    CONTENT
  </div>
</div>
如果你想让“T”更靠近右边缘,你可以增加letter-spacing一点。对于 Stack Overflow 的代码片段,将其设置为可以解决14.67vw问题:
html, body {
  margin: 0;
  height: 100%;
  width: 100%;
}
.container{
  background: tomato;
  height: 10%;
  width: 100%;
}
.content {
  color: white;
  letter-spacing: 14.67vw;
  overflow: hidden;
}
<div class="container">
  <div class="content">
    CONTENT
  </div>
</div>
如果您不需要语义化,我的意思是如果您只需要视觉结果,另一种解决方案是使用 flexbox。
所以你有你的<div id="#myText">TEXT 1</div>
我们需要得到这个:
<div id="#myText">
    <span>T</span>
    <span>E</span>
    <span>X</span>
    <span>T</span>
    <span> </span>
    <span>1</span>
</div>
那么你可以应用CSS:
#myText {
   display: flex;
   flex-direction: row;
   justify-content: space-between;
}
为了将文本转换为跨度,您可以使用 jQuery 或其他任何东西。这里有 jQuery:
var words = $('#myText').text().split("");
$('#myText').empty();
$.each(words, function(i, v) {
    if(v===' '){
        $('#myText').append('<span> </span>');
    } else {
        $('#myText').append($("<span>").text(v));
    }
});
为了获得更好的结果,请将 put letter-spacing: 0 删除到 #myText 中,以便应用任何额外的间距。
我写了一个 jQuery 代码片段来计算要应用的字母间距,以便文本使用它的容器的整个宽度:拉伸文本以适应 div 的宽度。
您可以将其应用于文本并在调整窗口大小时触发它,以便在调整浏览器大小时重新计算字母间距:
HTML:
<div class="container">
    <div class="stretch">CONTENT</div>
</div>
jQuery :
$.fn.strech_text = function(){
    var elmt          = $(this),
        cont_width    = elmt.width(),
        txt           = elmt.text(),
        one_line      = $('<span class="stretch_it">' + txt + '</span>'),
        nb_char       = elmt.text().length,
        spacing       = cont_width/nb_char,
        txt_width;
    elmt.html(one_line);
    txt_width = one_line.width();
    if (txt_width < cont_width){
        var  char_width     = txt_width/nb_char,
             ltr_spacing    = spacing - char_width + (spacing - char_width)/nb_char ; 
        one_line.css({'letter-spacing': ltr_spacing});
    } else {
        one_line.contents().unwrap();
        elmt.addClass('justify');
    }
};
$(document).ready(function () {
    $('.stretch').strech_text();
    $(window).resize(function () { 
        $('.stretch').strech_text();
    });
});
CSS:
html, body{
    height: 100%;
    margin:0;
}
.container{
    height: 10%;
    background: red;
}
.stretch{
    overflow-x:hidden;
}
.stretch_it{
    white-space: nowrap;
}