|      1tutou      2023-01-14 14:56:05 +08:00 你添加一段 js ,直接改 dom 不就行了 | 
|  |      2fason1995      2023-01-14 15:04:28 +08:00 先把 html 字符串 innerHTML 到 dom 中,然后选择 dom ,添加属性就好了 | 
|  |      4lukaz      2023-01-14 15:08:11 +08:00 via iPhone 可以考虑用正则匹配替换 | 
|  |      5DrugsZ      2023-01-14 15:09:37 +08:00 直接把<table 替换成 <table border="1" | 
|  |      6gydi      2023-01-14 15:11:24 +08:00  1 正则或者 DOMParser | 
|      7fox0001      2023-01-14 15:12:07 +08:00 via Android @tutou #1 我也推荐这个做法。在该 HTML 末尾加段<script>,该 HTML 加载完就会自行 js 并做修改。至于 js ,可以用 dom 的相关方法,不用替换字符串那么麻烦。 | 
|  |      9learningman      2023-01-14 15:29:11 +08:00 @MissSixty #8 容易出错就 DomParser 啊,楼上不是有人说过了吗 | 
|  |      10lanced      2023-01-14 16:06:32 +08:00 可以看一下 DocumentFragment ,创建并组成一个 DOM 子树,再用 2 楼的方法去修改,再插入 Document ,只触发一次重渲染 | 
|  |      11molvqingtai      2023-01-14 16:09:38 +08:00 via Android @lukaz 不要误导人,能精确匹配 html 的正则还没有写出来 | 
|      12AyaseEri      2023-01-14 16:21:15 +08:00  2 让后端在 html 里给你留两个槽,你直接 replace | 
|      13mango111      2023-01-14 16:21:52 +08:00 之前用过一个库 cheerio  https://www.npmjs.com/package/cheerio 可以解析 html 字符串,用类 jQuery 方式修改 dom 并输出新字符串 | 
|  |      14codehz      2023-01-14 16:49:11 +08:00 via iPhone table 的 border 真的需要改 html 吗( css 不可以吗 | 
|      15humbass      2023-01-14 16:58:45 +08:00 String.replace 支持正则,基础还是需要敲打的 | 
|  |      16lzgshsj      2023-01-14 17:01:09 +08:00 cheerio+1 | 
|      17lneoi      2023-01-14 17:15:37 +08:00 htmlparser2 找个类似的解析库操作一下 | 
|      18renmu      2023-01-14 17:21:27 +08:00 via Android 改 dom 性能差,那我想知道你们是怎么做交互的 | 
|  |      20darkengine      2023-01-14 17:43:08 +08:00  1 建议先考虑怎么实现,再考虑性能问题,不要提前优化。 | 
|  |      21xiangyuecn      2023-01-14 17:49:14 +08:00  1 #12 的 也许才是跨语言并且简单的实现,其他的解析要么太重量级了 正则:只要特征明显,正则替换就容易 且 准确;特征不明显 容易搞砸 且 不容易调试发现错误 | 
|  |      22bgm004      2023-01-14 18:43:55 +08:00 via Android 推荐 10 楼的方法 | 
|      23iOCZ      2023-01-14 18:58:52 +08:00 源头修改 | 
|      24PlG5sBkXD1ziLeGB      2023-01-14 19:44:06 +08:00 via iPhone 看起来像是打印表单,其实这种后端返回数据,前端生成表单更简单一点 | 
|      25zhuangpipi      2023-01-14 19:45:14 +08:00 html to ast ,修改完再 generate 成 html | 
|  |      26cpstar      2023-01-14 20:29:02 +08:00 赞同 20#,提了这个建议不行,那个建议也不行,那不就是既要又要。所有的方法都是有优有劣的,只看劣势不看优势,那没有万全之策。 | 
|      27MissSixty OP 这个需求目的是后端返回 html 字符串前端调用浏览器打印,打印前在字符串中插入特定内容<div>和改变字符串中 table 的样式,目前总结了几种方法。 1 、在 HTML 末尾加段<script>,该 HTML 加载完就会自行 js 并做修改:这种行为有些危险,html 内容是用户随便写的。 2 、后端在 html 里留两个槽,直接 replace:这就相当于把问题丢给了后端去解决,既然都能留槽了那直接让后端来做多好。留槽和插入 div 也没啥区别。 3 、正则:改变 table 属性挺好用,但插入特定内容的 div 有不确定性,不敢保证写出的正则就那么强大。 4 、document.implementation.createHTMLDocument():内存中创建空白网页,然后使用 documentElement.innerHTML 来存放内容,接着就使用常规 dom 操作。目前使用此方法。 5 、innerHTML:此方法使用跟第 2 个类似,但它会自动去掉 html 、head 、body 标签,不是完整的网页了。 6 、new DOMParser():使用起来很简单,也是个能解决问题的方法,但综合考虑还是第 2 个好一些。 | 
|  |      28webcape233      2023-01-15 09:31:35 +08:00 via iPhone 考虑下 css 直接加样式吧 | 
|  |      29duan602728596      2023-01-15 09:35:53 +08:00  1 虽然都说 js 操作 dom 的性能差,但是还没有差到操作几个 div 就被人说性能开销太大了的程度。 | 
|  |      30izoabr      2023-01-15 21:30:17 +08:00 后端给的内容能协商不?让加个 id 或者 class 呗 |