我想在HTML文档中标记一个电话号码为可调用链接。我读过微格式方法,我知道tel:方案是标准的,但实际上没有实现。

据我所知,Skype定义了Skype:和callto:,后者已经获得了一些流行。我想,其他公司要么有其他的计划,要么就搭上了“呼叫列车”。

什么是标记电话号码的最佳实践,以便尽可能多的人使用VoIP软件只需点击链接就可以接听电话?

额外的问题:有人知道紧急号码的并发症吗,比如美国的911或德国的110 ?

更新:Microsoft NetMeeting在WinXP下接受callto:方案。这个问题表明,Microsoft Office Communicator将处理tel:方案,但不处理callto: ones。好,雷蒙德!

更新2:现在已经过去两年半了。这似乎可以归结为你想用这个数字做什么。在移动环境中,tel:是可行的。如果你认为你的用户更多是Skype用户(callto:),或者更可能安装谷歌Voice (tel:)之类的东西,这取决于你。我个人的观点是,有疑问时使用tel:(与@Sidnicious的回答一致)。

更新3:用户@rybo111指出,Chrome中的Skype同时也加入了tel:潮流。我无法证实这一点,因为没有一台机器同时拥有这两种设备,但如果这是真的,这意味着我们终于有了一个赢家:tel:


当前回答

我使用正常的<a href="tel:+123456">12 3456 </a>标记,并使这些链接不可点击的桌面用户通过指针事件:none;

a[href^="tel:"] {
    text-decoration: none;
}
.no-touch a[href^="tel:"] {
    pointer-events: none;
    cursor: text;
}

对于不支持指针事件的浏览器(IE < 11),可以使用JavaScript阻止点击(例如依赖于Modernizr和jQuery):

if(!Modernizr.touch) {
    $(document).on('click', '[href^="tel:"]', function(e) {
        e.preventDefault();
        return false;
    });
}

其他回答

由于callto:是每默认支持的skype(设置在skype设置),其他人也支持它,我建议使用callto:而不是skype:。

我会使用电话:(建议)。但是为了有一个更好的回退/不显示错误页面,我会使用这样的东西(使用jquery):

// enhance tel-links
$("a[href^='tel:']").each(function() {
    var target = "call-" + this.href.replace(/[^a-z0-9]*/gi, "");
    var link = this;

    // load in iframe to supress potential errors when protocol is not available
    $("body").append("<iframe name=\"" + target + "\" style=\"display: none\"></iframe>");
    link.target = target;

    // replace tel with callto on desktop browsers for skype fallback
    if (!navigator.userAgent.match(/(mobile)/gi)) {
        link.href = link.href.replace(/^tel:/, "callto:");
    }
});

这里的假设是,在userAgent-string中有移动标记的移动浏览器支持tel:协议。对于其余部分,我们将链接替换为callto:协议,以便在可用的情况下回退到Skype。

为了抑制不支持协议的错误页,链接指向一个新的隐藏iframe。

不幸的是,它似乎不可能检查,如果url已成功加载在iframe。似乎没有触发错误事件。

RFC3966为电话号码定义了IETF标准URI,即'tel:' URI。这是标准。没有类似的标准指定'callto:',这是Skype平台上的一个特殊约定,允许注册URI处理程序来支持它。

最好的办法是从tel开始:它可以在所有手机上使用

然后放入这段代码,它只在桌面上运行,并且只在单击链接时运行。

我使用http://detectmobilebrowsers.com/来检测移动浏览器,你可以使用任何你喜欢的方法

if (!jQuery.browser.mobile) {
    jQuery('body').on('click', 'a[href^="tel:"]', function() {
            jQuery(this).attr('href', 
                jQuery(this).attr('href').replace(/^tel:/, 'callto:'));
    });
}

所以基本上你涵盖了所有的基础。

Tel:在所有手机上都可以使用该号码打开拨号器

Callto:在您的计算机上工作,从firefox, chrome连接到skype

tel:方案在20世纪90年代末被使用,并在2000年初被RFC 2806记录在案(在2004年被更彻底的RFC 3966废止),并继续得到改进。支持电话:在iPhone上不是一个随意的决定。

callto:,虽然Skype支持,但不是标准,应该避免使用,除非特别针对Skype用户。

我吗?我只是开始在页面上包含正确形式的tel: uri(不嗅探用户代理),并等待世界上其他电话赶上:)。

例子:

< a href = tel: + 18475555555 > 1-847-555-5555 < / a >