替换背景图片 javascript

Replacing background image javascript

有没有办法用 javascript 更改背景图像样式?我目前有:

if($(".stLarge").attr.backgroundImage = "http://w.sharethis.com/images/facebook_32.png") {

      console.log('hello');
      $('.stLarge[backgroundImage="http://w.sharethis.com/images/facebook_32.png"]').attr("backgroundImage", "url(/images/facebook.png)";
    } 

它正在进入 if 语句,但没有执行图像更改。知道我做错了什么吗?提前致谢

我认为没有属性背景图片,你需要使用css

$('.stLarge[style*="background-image: url(http://w.sharethis.com/images/facebook_32.png)"]').css("background-image", "url(/images/facebook.png)");

jQuery - css() Method

jQuery 的语法错误和误用。这样做:

$('.stLarge').each(i, e){
  if($(e).css('backgroundImage').match(/url\(('|")?https?\:\/\/w\.sharethis\.com\/images\/facebook_32\.png()?\)/)){
    $(e).css('backgroundImage', "url('/images/facebook.png')");
  }
} 

BackgroundImage 是元素对象中 style 对象的 属性 而不是属性。您可以使用 jQuery .css() 方法更改和读取 css 属性。

var imgUrls = ['http://w.sharethis.com/images/facebook_32.png', '/images/facebook.png']
var $jq = $(".stLarge");
if($jq.css('background-image').indexOf(imgUrls[0]) > -1){
   $jq.css('background-image', 'url("' + imgUrls[1] + '")');
}