相关文章推荐
仗义的登山鞋  ·  EntryPointNotFoundExce ...·  1 年前    · 
宽容的小虾米  ·  aaudio - 信假名如 - 博客园·  1 年前    · 
爱跑步的松鼠  ·  Kaggle经验--时间序列预测真的需要深度 ...·  1 年前    · 
冲动的野马  ·  shell脚本:监控HTTP服务的状态(测试 ...·  1 年前    · 
一身肌肉的皮蛋  ·  数据迁移最快方式,多线程并行执行 ...·  2 年前    · 
Code  ›  使用 white-space 来实现保留文本域 textarea的换行格式和 空格格式开发者社区
html空格 html换行 textarea white-space
https://cloud.tencent.com/developer/article/1976360
英勇无比的铁链
2 年前
作者头像
拿我格子衫来
0 篇文章

使用 white-space 来实现保留文本域 textarea的换行格式和 空格格式

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > TopFE > 使用 white-space 来实现保留文本域 textarea的换行格式和 空格格式

使用 white-space 来实现保留文本域 textarea的换行格式和 空格格式

作者头像
拿我格子衫来
发布 于 2022-04-10 10:30:08
984 0
发布 于 2022-04-10 10:30:08
举报

背景

昨天产品需求评审,产品经理收到用户的反馈,在系统中有一些文本域,用户希望在在文本中填写的文本内容和格式都能够被保留下来,目前只能保存文本内容,对于文本域的换行和空格,在显示的时候都没有正确显示。

接到这个需求,我搜索了一下,网上大多数是获取文本域的内容后,将其中的换行符,空格替换成html标签,如 <br> , 使用JavaScript处理,然后将这些数据转化后,保存的后端,在显示时,使用innerHTML来显示到一个 div 或 p 标签内。这里有一个很大的安全隐患就是,脚本注入,如果用户输入了一些 script ,而这些又没经过处理直接使用 innerHTML 显示到页面上,这是很危险的。

于是我寻求另一种解决途径。 最终我发现设置元素样式的 white-space 可以将文本域的换行和空格正确显示出来。

white-space 属性解释

下面是white-space的几个值其及其解释

属性

换行符

空格和制表符

文字换行

行尾空格

normal

合并

合并

换行

删除

nowrap

合并

合并

不换行

删除

pre

保留

保留

不换行

保留

pre-wrap

保留

保留

换行

挂起

pre-line

保留

合并

换行

删除

break-spaces

保留

保留

换行

换行

normal

连续的空白符会被合并,换行符会被当作空白符来处理。换行在填充「行框盒子(line boxes)」时是必要。

nowrap

和 normal 一样,连续的空白符会被合并。但文本内的换行无效。

pre

连续的空白符会被保留。在遇到换行符或者 元素时才会换行。

pre-wrap

连续的空白符会被保留。在遇到换行符或者 元素,或者需要为了填充「行框盒子(line boxes)」时才会换行。

pre-line

连续的空白符会被合并。在遇到换行符或者 元素,或者需要为了填充「行框盒子(line boxes)」时会换行。

break-spaces

与 pre-wrap的行为相同,除了:

任何保留的空白序列总是占用空间,包括在行尾。 每个保留的空格字符后都存在换行机会,包括空格字符之间。 这样保留的空间占用空间而不会挂起,从而影响盒子的固有尺寸(最小内容大小和最大内容大小)。

演示demo

此外我还专门写了一个简单的demo来演示使用white-space来正确显示文本域中的文本格式。

在这里插入图片描述
在这里插入图片描述

由上图可见,将元素的 white-space 属性设置为 space-pre , pre-wrap , pre-line , break-space 都可以获得不错的效果

demo代码

<html>
    <title>保存文本域格式</title>
    <style type="text/css">
        .showtext {
            padding: 10px;
            border: 1px solid #ddd;
        .white-space-normal {
            white-space: normal;
        .white-space-nowrap {
            white-space: nowrap;
        .white-space-pre {
            white-space: pre;
        .white-space-pre-wrap {
            white-space: pre-wrap;
        .white-space-pre-line {
            white-space: pre-line;
        .white-space-break-spaces {
            white-space: break-spaces;
    </style>
</head>
    <div style="width: 800px; margin: 40px auto;">
        <textarea id="myinput" style="height: 200px; width: 200px;"></textarea>
        <button onclick="submit()">提交</button>
        <p id="normal" class="showtext white-space-normal">normal:</p>
        <p id="nowrap" class="showtext white-space-nowrap">nowrap:</p>
        <p id="pre" class="showtext white-space-pre">space-pre:</p>
        <p id="pre-wrap" class="showtext white-space-pre-wrap">pre-wrap:</p>
        <p id="pre-line" class="showtext white-space-pre-line">pre-line:</p>
        <p id="break-spaces" class="showtext white-space-break-spaces">break-spaces:</p>
    <script>
        function submit() {
            const inputValue = document.querySelector('#myinput').value
            console.log('文本域内容', inputValue);
            [...document.querySelectorAll('.showtext')].forEach(x => {
                x.append(inputValue)
 
推荐文章
仗义的登山鞋  ·  EntryPointNotFoundException:在DLL 'onnxruntime‘中找不到名为'OrtGetApiBase’的入口点-腾讯云开发者社区-腾讯云
1 年前
宽容的小虾米  ·  aaudio - 信假名如 - 博客园
1 年前
爱跑步的松鼠  ·  Kaggle经验--时间序列预测真的需要深度学习模型吗?_变量_Deep_向量
1 年前
冲动的野马  ·  shell脚本:监控HTTP服务的状态(测试返回码)_51CTO博客_shell监控脚本
1 年前
一身肌肉的皮蛋  ·  数据迁移最快方式,多线程并行执行 Sql插入 - 皓月青峰 - 博客园
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号