概述
本 Demo 展示了如何为单元格设置邮件地址超链接。通过 setHyperlink 方法将电子邮件地址设置为超链接,用户点击后可自动打开默认邮件客户端,提升邮件发送效率。
实现思路
使用 fromJSON 方法加载预设的表格数据(包含姓名等信息)
使用 suspendPaint 暂停渲染以提升性能
通过循环为第 4 列的多行单元格设置邮件地址超链接
使用 resumePaint 恢复渲染,显示最终效果
代码解析
批量设置邮件超链接
这段代码通过 setHyperlink 方法为单元格设置邮件地址超链接。url 属性设置为电子邮件地址时,SpreadJS 会自动识别并创建 mailto: 链接,点击后会打开默认邮件客户端。
性能优化
suspendPaint 和 resumePaint 用于暂停和恢复界面渲染。在批量设置多个超链接时,使用这两个方法可以避免每次设置都触发重绘,从而提升性能。
运行效果
表格第 4 列显示电子邮件地址,并以超链接样式呈现(蓝色文本)
鼠标悬停在邮件地址上时,鼠标指针变为手型
点击任意邮件地址,系统会打开默认邮件客户端,收件人栏自动填入该邮件地址
超链接支持各种常见的邮件地址格式,如 name@example.com、name_123@example.com 等
API 参考
setHyperlink 方法
row: 单元格所在行索引
col: 单元格所在列索引
value: 超链接信息对象,包含以下属性:
url: 字符串,超链接目标地址。设置为邮件地址时会自动创建 mailto: 链接
tooltip: 可选,鼠标悬停时显示的提示文本
linkColor: 可选,未访问时的链接颜色
visitedLinkColor: 可选,访问后的链接颜色
drawUnderline: 可选,是否绘制下划线,默认为 true
sheetArea: 可选,指定工作表区域,默认为 viewport
提示: 邮件地址超链接支持添加主题参数,例如: "email@example.com?subject=主题内容",点击后会打开邮件客户端并自动填入主题。
window.onload = initFunction;
function initFunction() {
var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"), {sheetCount: 2});
var sheet = spread.getActiveSheet();
spread.suspendPaint();
sheet.fromJSON(urlAddressJsonData);
sheet.setHyperlink(0, 4, { url: "John@example.com"});
sheet.setHyperlink(1, 4, { url: "kally@example.com"});
sheet.setHyperlink(2, 4, { url: "jozef95@example.com"});
sheet.setHyperlink(3, 4, { url: "Hapk@example.com"});
sheet.setHyperlink(4, 4, { url: "patricia_96@example.com"});
sheet.setHyperlink(5, 4, { url: "jadejean@example.com"});
sheet.setHyperlink(6, 4, { url: "luigi-84@example.com"});
sheet.setHyperlink(7, 4, { url: "kvetoslava95@example.com"});
sheet.setHyperlink(8, 4, { url: "irina-94@example.com"});
sheet.setHyperlink(9, 4, { url: "johnezf@example.com"});
spread.resumePaint();
}
<!doctype html>
<html style="height:100%;font-size:14px;">
<head>
<meta name="spreadjs culture" content="zh-cn" />
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" type="text/css"
href="$DEMOROOT$/zh/purejs/node_modules/@grapecity-software/spread-sheets/styles/gc.spread.sheets.excel2013white.css">
<script src="$DEMOROOT$/zh/purejs/node_modules/@grapecity-software/spread-sheets/dist/gc.spread.sheets.all.min.js"
type="text/javascript"></script>
<script
src="$DEMOROOT$/zh/purejs/node_modules/@grapecity-software/spread-sheets-resources-zh/dist/gc.spread.sheets.resources.zh.min.js"
type="text/javascript"></script>
<script src="$DEMOROOT$/spread/source/js/license.js" type="text/javascript"></script>
<script src="$DEMOROOT$/spread/source/data/hyperlink-data.js" type="text/javascript"></script>
<script src="app.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
<div class="sample-tutorial">
<div id="ss" class="sample-spreadsheets"></div>
</div>
</body>
</html>
.sample-tutorial {
position: relative;
height: 100%;
overflow: hidden;
}
.sample-spreadsheets {
width: 100%;
height: 100%;
overflow: hidden;
float: left;
}
.options-container {
float: right;
padding: 12px;
height: 100%;
width: 100%;
box-sizing: border-box;
background: #fbfbfb;
overflow: auto;
}
.option-row {
font-size: 14px;
padding: 5px;
}
input {
display:block;
width: 100%;
margin: 8px 0;
box-sizing: border-box;
}
label, input {
padding: 4px 6px;
}
body {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}
#drawUnderline {
display: inline-block;
width: 30px;
}
#drawUnderlineLabel {
display: inline-block;
}
#allowAutoCreateHyperlink {
display: inline-block;
width: 30px;
}