背景

今天测试人员测试出来一个显示数据的页面,没有换行。

原因剖析

这个页面是从一个<textarea>的页面拿到的数据,存到数据库中后再返回来的。

1.

知道这点之后,就有了调查方向了:先查看从数据库取出来的数据是否有换行的标识,经过调试发现确实有(chrome换行符显示的是一个回车键的图标)

2.

既然有换行符,那么就是存取数据都是原模原样的,那么在显示的时候除了问题,那么是不是<span>的问题,经过一番调查,span确实不能直接处理换行符,需要替换为<br />,这个是html换行标记了

于是使用正则替换str.replace(/\n/g,"<br />"),结果把要显示的内容的换行符替换为了<br />,但是还是直接显示了出来,并没有达到换行的目的,这个时候自己都怀疑是不是<span>不支持<br />,于是用了<div>替换了<span>标记,一样的没有换行。

3.

这个时候,基本上猜测就是angularjs转义了,之后又查了资料,发现<pre>标记可以使用,这个标记的描述是对原有内容原模原样的显示出来,也就是说<pre>可以直接的显示<textarea>的原始值,事实证明就是这样子的,但是它出现了一个黑灰色的背景框,这个可不是我想要的。

4.

既然是angularjs转义的,那么肯定有原始的解决方案,真让自己找到了,就是使用ng-bind-html指令,可是这个页面直接提示这个是一个不安全的操作,都提供了这个指令了,还提示安全问题,那么肯定有对策,果然让自己找到了,必须配合$sce服务使用

最终解决方案

  1. 使用<pre>直接显示值,就是有背景。

    <pre>{{data}}</pre>
  2. 在页面中使用ng-bind-html指令配合$sce

    //js
    app.filter('trustHtml',function($sce){
    return function(input){
    return $sce.trustAsHtml(input.replace(/ /g,'&nbsp;').replace(/\n/g,'<br />'));
    };
    });
    //html
    <span ng-bind-html="data | trustHtml"><span>

回顾

自己出错的地方

  1. <span>标记不支持<br />
  2. 先处理的<br />的标记,之后才处理了空格

没有考虑的地方

  1. 空格的处理没有考虑到
  2. 先处理空格和转义字符的结果是不同的。

知识点

  1. angularjs把赋值都进行了转义
  2. <testarea>直接支持换行
  3. <pre>标记也支持换行
  4. <textarea>的换行符是\n
  5. angularjs使用ng-bind-html指令显示html的值
  6. html的直接支持是危险的,所以要使用$sce.trustAsHtml方法进行手动信任一次。
  7. /\n/只能替换第一个换行符,//g是替换所有的(g代表global)。
  8. angularjs的filter是返回一个函数,且第一个参数是输入的值

扩展

  1. 注意转义的问题。
  2. 注意一些标签是支持换行、空格的。
  3. $sce.trustAsHtml处理html,因为看到了As,那么也就支持其他的AsXXX方法了,有哪些?
  4. filter的4中用法:{{data | filter1}},ng-bind-html="data | fitler1",fitler1(data),$filter('fitler1')(data)
  5. filter的多个参数的形式是一样的。
  6. linux 管道 |符号的概念:把前面的结果当做后面的输入的参数

angularjs中类似textarea的换行、空格处理的更多相关文章

  1. 在使用easyui,datagrid时,JSON中的如果含有换行符,则不能显示数据

    http://www.xuebuyuan.com/2103538.html 每项值需处理换行符 item = item.Replace("\r\n", ""); ...

  2. AngularJS 中的Promise --- $q服务详解

    先说说什么是Promise,什么是$q吧.Promise是一种异步处理模式,有很多的实现方式,比如著名的Kris Kwal's Q还有JQuery的Deffered. 什么是Promise 以前了解过 ...

  3. AngularJS中的表单验证

    AngularJS中的表单验证 AngularJS自带了很多验证,什么必填,最大长度,最小长度...,这里记录几个有用的正则式验证 1.使用angularjs的表单验证 正则式验证 只需要配置一个正则 ...

  4. 关于angularjs中的jQuery

    关于angularjs中的jQuery 下面是一个小例子,用来说明我经常看到的一种模式.我们需要一个开关型的按钮.(注意:这个例子的代码有点装逼,并且有点冗长,只是为了用来代表更加复杂一些的例子,这些 ...

  5. AngularJS中的指令全面解析(转载)

    说到AngularJS,我们首先想到的大概也就是双向数据绑定和指令系统了,这两者也是AngularJS中最为吸引人的地方.双向数据绑定呢,感觉没什么好说的,那么今天我们就来简单的讨论下AngularJ ...

  6. 在Visual Studio中使用正则表达式匹配换行和批量替换

    系统环境:Windows 8.1 Enterprise Update 2 x64 开发环境:Mircosoft Visual Studio Ultimate 2013 Update 2 RC 问题:如 ...

  7. AngularJS中实现无限级联动菜单(使用demo)

    昨天没来得及贴几个使用demo,今天补上,供有兴趣的同学参考 :) 1. 同步加载子选项demo2. 异步加载子选项demo3. 初始值回填demo4. 倒金字塔依赖demo directive的源代 ...

  8. 关于input/textarea提交内容空格回车转换问题,以及ng-model去除空格问题

    input/textarea提交内容空格回车转换问题 /*my-enter-bind.js*/ /*回车换行显示转义*/ 'use strict'; angular.module('app') .di ...

  9. AngularJS学习--- AngularJS中XHR(AJAX)和依赖注入(DI) step5

    前言:本文接前一篇文章,主要介绍什么是XHR,AJAX,DI,angularjs中如何使用XHR和DI. 1.切换工具目录 git checkout -f step- #切换分支 npm start ...

随机推荐

  1. Handler processing failed; nested exception is java.lang.NoClassDefFoundError: javax/servlet/jsp/jstl/core/Config解决

    出现这个问题往往伴随  HTTP-500错误 报错信息: HTTP Status - Handler processing failed; nested exception is java.lang. ...

  2. Android 通知 相关api记录

    记录帖 通知(Notification) 的API 1.使用getSystemService()方法获取系统服务,参数接收一个字符串来确定获取具体的服务,使用通知传入Content.NOTIFICAT ...

  3. MLlib--SVD算法

    转载请标明出处http://www.cnblogs.com/haozhengfei/p/4db529fa9f4c042673c6dc8218251f6c.html SVD算法 1.1什么是SVD?   ...

  4. 如何让phpmyadmin输入密码再进入

    分类: wamp 对于很多不熟悉PHP环境安装的朋友来说,用集成环境可以更快的上手,更方便的搭建PHP的运行环境,但是,WAMP的集成环境仅仅是将底层基础工作做好了,有些个别关键的配置操作并没有集成到 ...

  5. 什么是A记录/CNAME记录/MX记录/TXT记录

    答: A 记录(Address)是用来指定主机名(或域名)对应的IP地址记录.当你输入域名的时候给你引导向设置在DNS的A记录所对应的服务器. CNAME记录 ( Canonical Name )是一 ...

  6. 将js进行到底:node学习笔记1

    废话:自高中以来一直对编程充满激情,磨剑五年,如今要毕业了,我不想用我已经擅长的知识敷衍,而想以一个全新的领域去面向我的毕设--是时候学习一下node.js node.js基础 对于JavaScrip ...

  7. Asp.net mvc 中Action 方法的执行(二)

    [toc] 前面介绍了 Action 执行过程中的几个基本的组件,这里介绍 Action 方法的参数绑定. 数据来源 为 Action 方法提供参数绑定的原始数据来源于当前的 Http 请求,可能包含 ...

  8. 自学python Day01

    What is Python 1. 面向对象的解释行语言 2. 非常丰富的库 3. 使用制表符作为语句缩进 (white space) 优点: 1. 免费.开源 2. 可扩展性.可嵌入性 3. 非常丰 ...

  9. winform程序压缩文件上传,服务器端asp.net mvc进行接收解压

    期间编程没什么难度,唯一可能忽略导致结果失败是asp.net  mvc配置 对于压缩文件大的话,需要配置mvc的最大接收量: <system.web> <httpRuntime ma ...

  10. linux如何自动获取ip地址

    第一步:激活网卡 系统装好后默认的网卡是eth0,用下面的命令将这块网卡激活. # ifconfig eth0 up 第二步:设置网卡进入系统时启动 想要每次开机就可以自动获取IP地址上网,就要设置网 ...