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