溢出的输入文本
Overflowing input text
以下是JSFiddle演示:http://jsfiddle.net/qox0yxb4/
我使用type()
来创建一个打字机效果(每个字符都打印在屏幕上,中间有一个延迟)。我使用addTextToScreen(textForScreen)
向队列添加文本,然后通过type()
将文本添加到屏幕上。当我从JavaScript中调用addTextToScreen()
时,文本似乎是格式化的,因为它不会在x轴上溢出,但是当我接受来自HTML <input>
标记(printText()
)的输入时,文本会在x轴溢出。
以下是JavaScript方法:
var i = 0,
isTag=false,
text;
var typeTime = 45;
function type() {
if (text === textOnScreen){
setTimeout(function(){type();}, typeTime);
return;
}
text = textOnScreen.slice(0, i+1);
i++;
document.getElementById('paraText').innerHTML = text;
var char = text.slice(-1);
console.log(char);
if( char === '<' ) isTag = true;
if( char === '>' ) isTag = false;
if (isTag) return type();
setTimeout(function(){type();}, typeTime);
}
function addTextToScreen(textForScreen){
textOnScreen = textOnScreen + textForScreen;
}
type();
function printText(event) {
if(event.keyCode == 13){
printText = document.getElementById("inputText").value.toString();
addTextToScreen("<br>" + printText.toString());
x = document.getElementById("inputText");
x.value = "";
}
}
我还注意到,每当我将文本粘贴到输入框中时(文本可以来自任何地方),它似乎是格式化的,并且不会溢出。
将此css属性添加到#paraText
:
word-wrap:break-word;
JS Fiddle演示
Josh建议使用break-all
,区别如下。
您缺少的神奇CSS规则是word-break: break-all;
。再加上这个,它的工作原理就像你所期望的那样。
证明
相关文章:
- 让文本输入幻灯片显示输入时的新文本输入?然后向后滑动
- Sails.js:同时发布文本输入和一个文件
- 来自文本输入null的html javascript变量
- 当没有文本输入聚焦时检测空格键按下
- JS中的按钮和文本输入
- JavaScript:在调用函数的文本输入上按enter键
- jQuery自动完成功能不适用于多个文本输入
- 使用JS从选择和文本输入中捕获值,并将输出返回到HTML
- 如何通过jQuery发送选定的元素和文本输入
- HTML如何根据javascript函数的返回值限制文本输入
- jquery插件或javascript方法自动调整文本输入(而非文本区域)(固定宽度)可变高度的大小
- 在jquery中获取文本输入val始终为空
- HTML文本输入大小
- 文本输入与文本区域
- 角度ui选择标记模糊时丢失文本输入
- 文本输入值中的JavaScript变量
- Angular指令中的最佳实践是将文本输入设置为英尺和英寸的格式
- 如何在不通过模型验证的情况下屏蔽文本输入中输入的字符
- 在文本输入区域中创建双向更新
- 不使用自定义CSS或HTML(使用框架方法)的角度材质文本输入或文本区域标签大小