jQuery从ajax加载的内容中替换字符串

问题描述 投票:0回答:1

我正在尝试将一个字符串的所有实例替换为另一个字符串。这是我到目前为止:

我通过ajax加载模板html文件,这是内容:

<div style="background-image:url({URL}/photo.png)">
    <div>
        <p>
           <h1>
             <a href="{URL}">link 1</a>
           </h1>
        </p>
        <a href="{URL}">link 2</a>
    </div>
</div>

所以基本上我需要用实际的url替换{URL}的所有实例。

我试过这样的事情:

$.get("template.html")
    .done(function(data) {
        data.replace("/{URL}/g", "http://example.com");
});

要么:

$.get("template.html")
    .done(function(data) {
        $(data).html($(data).html().replace("{URL}", "http://example.com"));
});

但它们都不起作用。

jquery replace
1个回答
0
投票

使用全局替换的正确语法不是data.replace("/{URL}/g", "http://example.com");正确的语法是:data.replace(/{URL}/g, "http://example.com");

我尝试了下面的代码,它按预期工作:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script type="text/javascript">
        $().ready(function () {
            $.get("template.html", )
                .done(function (data) {
                    data = data.replace(/{URL}/g, "http://yourdomain.com");
                    $("#content").html(data);
                                });
                });

    </script>
</head>
<body>
    <div id="content"></div>
</body>
</html>

请记住,data.replace()函数不会改变data对象的实际内容,因此我写了data = data.replace(/{URL}/g, "http://yourdomain.com");然后我将修改后的内容插入div标记内。最后,在你的template.html文件中,第一行应该是这样的:<div style="background-image:url('{URL}/photo.png)'">因为url()需要一个字符串!

请参阅JavaScript String replace() Method了解更多详情。

© www.soinside.com 2019 - 2024. All rights reserved.