HTML Email的编写

简介: 本文主要讲HTML Email的编写


总结回顾



一、HTML Email的编写开发场景


  • 你下单 可能 电商会给你发一份 详情邮件
  • 招行可能给你发下你的账单邮件
  • 生日了给你发个邮件
  • 转正了给你发个邮件
  • 入职周年邮件


二、遇到的问题


Email的兼容性很差


邮件内容所在上下文或者说所在外部容器(以下简称环境)都是由邮箱服务商决定的,不同的邮件服务商对前端样式布局支持都存在在一些差别。这就要求邮件内容需要在任何一种情况下都要正常兼容显示。


Email容器不同


你写的邮件前端代码可能被放在一个iframe中,那你的内容是被放在body里面的;可能放在一个div中,你的内容就被放在这个div里面。


Email自带设置


邮箱软件本身设置设置了些css,他可能对你产生未知的影响。可能根本没有申明doctype,即使申明了,也不是你想要的doctype。


避免被嵌套在不正确的容器里


因为容器可能是body或div,我们邮件内容不应该是一个完整的html。所以邮件内容应该是以div为根节点的html片段。


三、环境(外部容器)


我们写的邮件代码在不用的邮件服务商下,对应的外部容器不太一样。

QQ邮箱:自己编写的内容被嵌套在一个div中



outlook邮箱:自己编写的内容不知道被嵌套什么元素里了,它本身的元素加上我编写的元素被混在一起了


其他的邮箱你们可以自己测试一下


四、开发的Doctype


一个文档类型标记是一种标准通用标记语言的文档类型声明,它的目的是要告诉标准通用标记语言解析器,它应该使用什么样的文档类型定义(DTD)来解析文档。


兼容性最好的Doctype是XHTML 1.0 Strict,事实上Gmail和Hotmail会删掉你的Doctype,换上这个Doctype。使用这个Doctype,也就意味着,不能使用HTML5的语法。



五、开发的布局


  • 网页的布局(layout)推荐使用表格(table)
  • css内嵌,不能在head标签中写style,也不能外联。
  • 不能用浮动的方式定位。position:absolute;float:left;等都不行,float在qq邮箱客户端中可以识别,但是在outlook中无法识别。
  • 为了保证兼容性,需要把邮件的宽度设置为600px,最大600px;


网页的布局(layout)必须使用表格(table)。首先,放置一个最外层的大表格,用来设置背景。 在内层,放置第二个表格。用来展示内容。第二个table的宽度定为600像素,防止超过客户端的显示宽度。


六、开发的样式


  • 避免css冲突或被覆盖
  • 尽量使用div、span等无语义标签。
  • 尽量避免CSS属性值的简写形式
  • font-size:0; 很重要,否则qq邮箱 会自动填写很多空格,影响布局
  • 减少不必要的间隙和空格等存在,影响页面美感


错误的写法
<div style="font: 8px/14px Arial, sans-serif; margin: 1px 0;"> 
推荐写法
<div style="margin-top: 1px; margin-bottom: 1px; margin-left: 0; margin-right: 0;">


所有的CSS规则,最好都采用行内样式。因为放置在网页头部的样式,很可能会被客户端删除。客户端对CSS规则的支持情况 另外,不要采用CSS的简写形式,有些客户端不支持。因为环境中可能已经设置了css,比如一些reset、一些.class。 所以我们只能使用行内style来确保我们的效果,并且在内容根节点上设置基础style,并且尽量使用div、span等无语义标签。


七、开发图片



  • 少用img,邮箱不会过滤你的img标签,但是系统往往会默认不载入陌生来信的图片
  • 需要img的话,一定要写好alt和title;
  • Outlook中img最高1728px,超过1728 的部分会被截掉
  • Outlook可能自动缩小img,使其最高位1728px,(上次测试没缩放,直接裁了)
  • 建议剪裁img,堆叠在一起
  • 有些客户端会给img链接加上边框,要去除边框。


<img border="0" style="display:block;
                    outline:none; 
                    text-decoration:none; 
                    -ms-interpolation-mode: bicubic;
                    border:none;"> 


图片是唯一可以引用的外部资源。其他的外部资源,比如样式表文件、字体文件、视频文件等,一概不能引用。 有些客户端会给图片链接加上边框,要去除边框。 需要注意的是,不少客户端默认不显示图片(比如Gmail),所以要确保即使没有图片,主要内容也能被阅读。


八、开发的background


  • 少用background 推荐尽可能使用切割的img
  • Gmail也不支持css里面的背景图
  • 在outlook2007、Outlook2010中,背景图片将无法显示



图片是唯一可以引用的外部资源。其他的外部资源,比如样式表文件、字体文件、视频文件等,一概不能引用。 有些客户端会给图片链接加上边框,要去除边框。 需要注意的是,不少客户端默认不显示图片(比如Gmail),所以要确保即使没有图片,主要内容也能被阅读。


九、email兼容总结


  • 最好使用TABLE标签布局 ,通过tr td来控制距离 空白区域等
  • 每个标签设置:margin:0;padding:0;font-size:0;(注意拆开写)
  • 设置 width, height
  • 少用img ,少用background
  • 邮件不支持js,a标签慎用
  • 在使用行高前建议添加mso-line-height-rule:exactly
  • margin:0; padding: 0;colspan="1" height="375" 顺序不可换


客户端:foxmail outlook QQ邮箱 为了应付Email的怪癖,花了很多时间测试,确保搞定了所有Outlook的坑洼沟洄 但是....还是不可避免有兼容问题 如果你只要兼容 Foxmail and qq邮箱,那你几乎可以像写web一样写邮件。 由于邮件客户端对css支持各有不同,所以一定要多测试再发送,保证样式的正确。如果出现了不兼容的情况,一定要耐心的使用最简单的方式进行兼容,尽量少用特殊标签及比较复杂的属性。

拜小白
+关注
目录
打赏
0
0
0
0
0
分享
相关文章
HTML5 input 类型: email及url
原文地址: HTML5′s “email” and “url” Input Types原文日期: 2010年09月15日 翻译日期: 2013年08月13日 在前面的博文,我们已经讨论了一些HTML5改进的地方,比如placeholder,prefetching以及webStorage,下面我要介绍的是两个新的input元素类型: email和url。
891 0
征信报告修改器,征信报告生成器,制作软件无痕修改软件【js+html+css】
本项目为信用评分模拟器教学工具,采用HTML5实现,仅供学习参考。核心功能通过JavaScript构建,包含虚拟数据生成、权重分配及信用因素分析(如还款记录、信用使用率等)。
抖音快手小红书虚拟评论截图生成器,模拟对话制作工具,html+js+css
这是一款纯前端实现的多平台虚拟评论生成器,支持抖音、快手、小红书风格,适用于产品演示与UI设计。采用Vanilla JS与Flexbox布局,利用IndexedDB存储数据,CSS Variables切换主题。
个人征信电子版无痕修改, 个人信用报告pdf修改,js+html+css即可实现【仅供学习用途】
本代码展示了一个信用知识学习系统的前端实现,包含评分计算、因素分析和建议生成功能。所有数据均为模拟生成
病历单生成器在线制作,病历单生成器app,HTML+CSS+JS恶搞工具
本项目为医疗病历模拟生成器,旨在为医学教学和软件开发测试提供数据支持,严格遵守《医疗机构病历管理规定》。
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
个人征信PDF无痕修改软件,个人征信模板可编辑,个人征信报告p图神器【js+html+css仅供学习用途】
这是一款信用知识学习系统,旨在帮助用户了解征信基本概念、信用评分计算原理及信用行为影响。系统通过模拟数据生成信用报告,涵盖还款记录
制作b超单生成器, 假怀孕b超单图片制作, p图医院证明【css+html+js装逼恶搞神器】
本资源提供一个适合用于熟人之间恶搞的工具,效果逼真,仅供学习参考与娱乐。包含前端技术学习要点:语义化布局、响应式设计、Flexbox、图片自适应
处方单图片生成器, 处方单在线制作免费,js+css+html恶搞神器
这是一个电子处方模拟生成系统,使用html2canvas库实现图片导出功能。系统生成的处方单包含多重防伪标识,并明确标注为模拟数据,仅供学习

热门文章

最新文章

AI助理
登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问

你好,我是AI助理

可以解答问题、推荐解决方案等