使用JS在可见的换行符上拆分文本[无\ n或<br/>]

时间:2018-09-12 12:04:09

标签: javascript split line-breaks

我的跨度为max-width,长文本为\ n或
。是否可以通过JS获取自动生成的换行符的位置?

例如,小范围内的“ Lorem ipsum dolor sit amet,consetetur sadipscing elitr,sed diam voluptua”就是这样,例如:

“ Lorem ipsum dolor sit amet, [break]
consetetur sadipscing elitr, [break]
sed diam voluptua”

我需要在休息时分割行或获取“隐藏的换行”字符的索引。

https://jsfiddle.net/DerLangeVonTetris/x63Ldcez/

HTML:

<h1 class="multiline-headline">
    <span class="decoration-text">Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam voluptua</span>
</h1>
<div class="preview"></div>

JS:

(function () {
    var span = document.getElementsByTagName('span')[0],
        spanLines = [];

    // do magic start

    spanLines.push(span.innerText.slice(0,27));
    spanLines.push(span.innerText.slice(28,56));
    spanLines.push(span.innerText.slice(57));

    // do magic end

    document.getElementsByClassName('preview')[0].innerText = JSON.stringify(spanLines);    

}(window));

结果:

["Lorem ipsum dolor sit amet,","consetetur sadipscing elitr,","sed diam voluptua"]

为什么我需要这个:

https://jsfiddle.net/DerLangeVonTetris/xgbsvpdy/

当我添加
时,突破装饰的Polyfill“ decofill”在Edge上运行。但是在响应式视图中,当我添加硬编码的HTML换行符时会遇到问题。因此,我需要将它们添加到客户端。

1 个答案:

答案 0 :(得分:0)

我喜欢你的问题!挑战很大,我喜欢挑战!

我将使用自己的技巧来回答这个问题(通过originalObjects,这是第一次-完全不同)

pure js
function MyOwnSplit(myTextDiv){
  var res = myTextDiv.innerHTML.trim().split(/ +/).map(function(t){
    return "<span>"+t+" </span>";
  });
  var mainText = myTextDiv.innerHTML;
  var fakeDiv=document.createElement("div");
  fakeDiv.innerHTML=res.join("");
  fakeDiv.setAttribute("style", myTextDiv.getAttribute("style"));
  fakeDiv.style.visibility='hidden';
  myTextDiv.insertAdjacentElement("afterend", fakeDiv);
  var finalRes={}, l=0, prvCTop=-Infinity;
  fakeDiv.childNodes.forEach(function(c){
    var top = c.offsetTop, A;
    if(top!=prvCTop) {
      l+=1;
      finalRes[l]=(A=[]);
      prvCTop=top;
    } else A=finalRes[l];
    A.push(c.innerHTML.trim());
  });
  fakeDiv.parentElement.removeChild(fakeDiv);
  return finalRes;
}
var res=MyOwnSplit(document.querySelector(".my-text"));
console.log(JSON.stringify(res));
//or getting all lines:
var r={};
for(var lN in res) {r["Line"+lN]=res[lN].join(" ");};
console.log(JSON.stringify(r));

  • result1是一个对象,每个键是相关行的数量,值是该行的单词。

  • result2是一个对象,每个键是行号,value是行本身。