Html移动端保存电话到手机通讯录

序言

本文主要是讲解在html移动端中,点击电话号码时,将电话号码保存到手机的通讯录中。该功能在Android系统和IOS系统中实现有所不同,Android利用a标签中的WTAI协议进行实现。而在IOS系统中,目前只了解到了能在Safari浏览器中利用生成vcf文件进行实现。

一、Android实现

WTAI介绍

WTAI 全称Wireless Telephony Applications Interface 。 目前,越来越多的浏览器都支持这个功能,但还不是所有。Phone.com, Mitsubishi 和 Ericsson 已经在浏览器中集成了。 在WML中可以调用设备的WTAI函数来呼叫特定的电话号码(最常用的功能之一)。

代码实现

以下列举了拨打电话和保存通讯录的代码,tel在Android和IOS中都支持。

<html>
    <head></head>
    <body>
        <a href="tel://13191835108"> 
	        点击拨打电话
        </a>
        <a href="wtai://wp/mc;13191835108">
            点击保存到通讯录
        </a>
    </body>
</html>

二、IOS系统实现

VCF文件介绍

VCF格式通讯录格式用途广泛,一般诺基亚、摩托罗拉手机导出通讯录的格式即为VCF。可以把VCF格式保存到电脑上以备不时之需。而且很多网上通讯录的导入格式也是VCF,例如飞信就加入了导入联系人的功能,可以把手机通讯录导入飞信的通讯录里,这样不管你手机在不在,只要有一台电脑就可以对自己的通讯录里的人了如指掌了。

代码实现

创建一个vcf文件放入到a标签的href属性中,点击a标签即可实现保存通讯录。

<html>
<head></head>
<body>
    <a id="card_btn_phone" href="">点击在Safari中保存到通讯录</a>
    <script>
        var contact = {
            name: '姓名',
            phone: '17778789898',
            email: '123@qq.com'
        };
        // create a vcard file
        var vcard = "BEGIN:VCARD\nVERSION:4.0\nFN:" + contact.name + "\nTEL;TYPE=work,voice:" + contact.phone + "\nEMAIL:" + contact.email + "\nEND:VCARD";
        var blob = new Blob([vcard], { type: "text/vcard" });
        var url = URL.createObjectURL(blob);
        document.getElementById('card_btn_phone').download = contact.name + ".vcf";
        document.getElementById('card_btn_phone').href = url
    </script>
</body>
</html>

 参考该链接iphone - save contacts using safari - Stack Overflow

三、拓展

1、邮箱唤起

<a id="card_btn_email" href="mailto:123@qq.com">

2、文本复制(可应用于快速复制电话号码或者邮箱)

function textCopy(t) {
    // 如果当前浏览器版本不兼容navigator.clipboard
    if (!navigator.clipboard) {
        var ele = document.createElement("input");
        ele.value = t;
        document.body.appendChild(ele);
        ele.select();
        document.execCommand("copy");
        document.body.removeChild(ele);
        if (document.execCommand("copy")) {
            console.log("复制成功!");
            copyAnimination()
        } else {
            console.log("复制失败!");
        }
    } else {
        navigator.clipboard.writeText(t).then(function () {
            console.log("复制成功!");
            copyAnimination()
        }).catch(function () {
            console.log("复制失败!");
        })
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Winter Li

拜托拜托,老板赏赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值