Shopify“ mailto:”标签问题

时间:2018-10-11 11:15:29

标签: javascript php shopify shopify-app

我在shopify商店中遇到外部链接问题。

我正在通过我的应用程序注入脚本,以显示带有锚标记的气泡,以将用户重定向到给定的链接。但是shopify如下将锚标记更改为以下链接:-

 <a href="/cdn-cgi/l/email-protection#076e69616847736274732964686a"><span style="color:#999999;">??Click here </span></a>

此链接导致404错误,找不到页面。

这是我的js代码

if (typeof jQuery == 'undefined') {
    var headTag = document.getElementsByTagName("head")[0];
    var jqTag = document.createElement('script');
    jqTag.type = 'text/javascript';
    jqTag.src = 'https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js';
    headTag.appendChild(jqTag)
} else {
    var $ = jQuery.noConflict()
}
var headTag = document.getElementsByTagName("head")[0];
var jqTag = document.createElement('script');
jqTag.type = 'text/javascript';
jqTag.src = '//cdn.jsdelivr.net/emojione/1.5.2/lib/js/emojione.min.js';
headTag.appendChild(jqTag)

$(document).ready(function(){
    var shop_name = Shopify.shop;
    $.ajax({
        url:'https://deepak.com/client/ajax_response.php',
        type:'post',
        data:{store_name:shop_name},
        success:function(data){
            if(data != '0'){
                $('body').append(data);
            }
        },
        error:function(){
            console.log('Network error');
        }
    })
});

,返回的响应是

<div id="bubbleChatBox"><a href="/cdn-cgi/l/email-protection#c5acaba3aa85b1a0b6b1eba6aaa8"><span style="color:#999999;">Click here </span></a>
</div><script data-cfasync="false" src="/cdn-cgi/scripts/5c5dd728/cloudflare-static/email-decode.min.js"></script>

我还没有添加email-decode.min.js,但它会自动添加到我的回复中。

链接应正确显示如下(期望结果):-

<a href="mailto:info@test.com"><span style="color:#999999;">Click here </span></a>

请帮助我。

3 个答案:

答案 0 :(得分:1)

不幸的是,我没有使用Shopify,所以我无法对其进行测试,但这似乎是服务器处理的。解决方法可能是执行以下操作:

  1. 在您的success:函数中,在$('body').append(data);之后添加以下内容:

    document.getElementById('bubbleChatBox').childNodes[0].setAttribute("href", "mailto:info@test.com");
    

这将使用Javascript将所需的HTML加载到文档中,然后由服务器处理并由客户端接收。请让我知道它是否有效!

答案 1 :(得分:1)

我不知道如何使用Shopify解决问题。但是一个技巧使我的代码正常工作。

我只是将“ mailto”更改为“ @mailto”,同时保存在数据库中,并在shopify商店中注入脚本后。我将“ @mailto”更改为“ mailto”,并且有效。

我使用以下代码使其正常工作。

<script>
    $("#bubbleChatBox a").each(function() {
        var text = $(this).attr("href");
        $(this).attr("href",text.replace("@mailto", "mailto"));
    });
</script>

答案 2 :(得分:1)

该商店似乎在Cloudflare的后面,并使用了其Email Address Obfuscation功能。可以在Cloudflare控制面板中禁用此功能,也可以根据具体情况使用以下标记禁用该功能:

<!--email_off--><a href="mailto:foo@bar.test"></a><!--/email_off-->