1

我有一个网络应用程序,它用其他 img 替换了几个 img。

例如:路径为http://example.com/example/example/images/dir/1.gif的图像被替换为http://cdn.example.com/dir/1.gif

为此,我使用 jQuery attr()。

所以我的代码看起来像这样:

$('img[src="http://www.example.com/dir/images/dir/1.gif"]').attr('src', "http://cdn.example.com/dir/1.gif");
$('img[src="http://www.example.com/dir/images/dir/2.gif"]').attr('src', "http://cdn.example.com/dir/2.gif");
$('img[src="http://www.example.com/dir/images/dir/3.gif"]').attr('src', "http://cdn.example.com/dir/3.gif");
$('img[src="http://www.example.com/dir/images/dir/4.gif"]').attr('src', "http://cdn.example.com/dir/4.gif");
$('img[src="http://www.example.com/dir/images/dir/5.gif"]').attr('src', "http://cdn.example.com/dir/5.gif");
$('img[src="http://www.example.com/dir/images/dir/6.gif"]').attr('src', "http://cdn.example.com/dir/6.gif");
$('img[src="http://www.example.com/dir/images/dir/7.gif"]').attr('src', "http://cdn.example.com/dir/7.gif");
$('img[src="http://www.example.com/dir/images/dir/8.gif"]').attr('src', "http://cdn.example.com/dir/8.gif");
$('img[src="http://www.example.com/dir/images/dir/9.gif"]').attr('src', "http://cdn.example.com/dir/9.gif");
$('img[src="http://www.example.com/dir/images/dir/10.gif"]').attr('src', "http://cdn.example.com/dir/10.gif")

那么有没有办法压缩这个?所以它是用更少的字符写的?

注意:在每一行中,两个网站上的图像都是相同的。例如,1.gif 再次替换为 1.gif,但使用了不同的服务器。所以基本上我想更换服务器。当http://www.example.com/dir/images/dir/替换为http://cdn.example.com/dir/

非常感谢

4

2 回答 2

1

你需要 JavaScript 的 .replace() 方法和正则表达式来替换东西。

在 jQuery 中,属性选择器^=意味着查找以开头的属性值。

试试这个,我假设它的所有图像都以“www.example.com”开头:

$('img[src^="http://www.example.com/dir/images/dir"]').attr('src',
    function(i,src){ 
        return src.replace('example.com/dir/images/dir','cdn.example.com/dir') 
});
于 2011-10-24T03:10:35.963 回答
1

就像使用循环一样简单:

var i;
for ( i = 1; i <= 10; i++ )
{
  $('img[src="http://www.example.com/dir/images/dir/'+i+'.gif"]').attr('src','http://cdn.example.com/dir/'+i+'.gif');
}

还是您要求为所有人进行查找和替换?

您可以使用attr 以 selector 开头

$('img[src^="http://www.example.com/"]').each(function(index,element){
  var $this, src, newSrc;
  $this = $(this);
  src = $this.attr('src');
  //do your replacement here
  newSrc = src.replace('www.example.com/dir/images/dir', 'cdn.example.com/dir');
  $this.attr('src', newSrc);
});

正如 Moin Zaman 指出的那样, attr 也可以将函数作为参数,这将这个脚本缩短为:

$('img[src^="http://www.example.com/"]').attr('src', function(index, src){
  return src.replace('www.example.com/dir/images/dir', 'cdn.example.com/dir');
});
于 2011-10-24T03:11:50.823 回答