当我们回复电子邮件时,如何从 gmail body 中删除跟踪像素?
How to remove tracking pixel from gmail body when we reply to a email?
在我的 chrome 扩展中,我使用 Inbox.sdk。
当有人发送电子邮件时,我会在其中添加一个跟踪像素。
但是当有人回复我们的邮件时。然后我们回复它 - 跟踪像素存在于 body 内部 - 在修剪部分 - 我们如何摆脱那个跟踪像素。
例如
A 和 B 正在对话,A 正在使用我的插件 -
一个 -------->。 B
(将附加一个跟踪像素TP1)
现在B会回复A
A <------------ B
当A回复B时
A ------------> B
(会附上新的追踪像素TP2)
但现在我们发送两个跟踪像素 -
1. TP2
2. TP1 - 因为它出现在回复的 body 中 - 在修剪后的内容中。
所以问题是我们如何从回复的 body 中删除旧内容。
通过使用收件箱 sdk,如果修剪内容以其他方式打开,我只能抓取 body - 我们无法抓取修剪内容男孩内部的内容。
如果问题不清楚,我可以评论,我会尝试扩展更多。
Gmail 使用 name="eut"
将修剪后的内容保存在隐藏的输入字段中。
您可以做的是获取消息正文,找到最近的祖父母table,它实际上封装了回复消息。然后找到这个输入元素,遍历它并删除所有跟踪像素。之后只需插入新的跟踪像素即可。
// get message body
var msg_el = composeView.getBodyElement();
// find the table which encapsulates the whole reply email.
var parent_div = el.closest('table').parentElement.closest('table').parentElement;
var email_form = parent_div.querySelector("form");
var form_input = email_form.querySelector('input[name="uet"]');
// get the trimmed text, convert it to a html object and remove tracking pixels
var email_text = form_input.value;
var images = $(email_html).find('img');
var val = null;
if (images.length > 0){
for (var i = 0; i < images.length; i++) {
var src = images[i].src;
// find tracking pixel using url
if (src.indexOf("tracking-pixel") !== -1){
email_html.find(images[i]).remove();
}
}
}
val = email_html.outerHTML;
el.outerHTML = val;
// Insert your tracking pixel here.
希望对您有所帮助。
在我的 chrome 扩展中,我使用 Inbox.sdk。
当有人发送电子邮件时,我会在其中添加一个跟踪像素。
但是当有人回复我们的邮件时。然后我们回复它 - 跟踪像素存在于 body 内部 - 在修剪部分 - 我们如何摆脱那个跟踪像素。
例如
A 和 B 正在对话,A 正在使用我的插件 -
一个 -------->。 B
(将附加一个跟踪像素TP1)
现在B会回复A
A <------------ B
当A回复B时
A ------------> B
(会附上新的追踪像素TP2)
但现在我们发送两个跟踪像素 -
1. TP2
2. TP1 - 因为它出现在回复的 body 中 - 在修剪后的内容中。
所以问题是我们如何从回复的 body 中删除旧内容。
通过使用收件箱 sdk,如果修剪内容以其他方式打开,我只能抓取 body - 我们无法抓取修剪内容男孩内部的内容。
如果问题不清楚,我可以评论,我会尝试扩展更多。
Gmail 使用 name="eut"
将修剪后的内容保存在隐藏的输入字段中。
您可以做的是获取消息正文,找到最近的祖父母table,它实际上封装了回复消息。然后找到这个输入元素,遍历它并删除所有跟踪像素。之后只需插入新的跟踪像素即可。
// get message body
var msg_el = composeView.getBodyElement();
// find the table which encapsulates the whole reply email.
var parent_div = el.closest('table').parentElement.closest('table').parentElement;
var email_form = parent_div.querySelector("form");
var form_input = email_form.querySelector('input[name="uet"]');
// get the trimmed text, convert it to a html object and remove tracking pixels
var email_text = form_input.value;
var images = $(email_html).find('img');
var val = null;
if (images.length > 0){
for (var i = 0; i < images.length; i++) {
var src = images[i].src;
// find tracking pixel using url
if (src.indexOf("tracking-pixel") !== -1){
email_html.find(images[i]).remove();
}
}
}
val = email_html.outerHTML;
el.outerHTML = val;
// Insert your tracking pixel here.
希望对您有所帮助。