javascript - 将 css background-image : url(. ..) 替换为 <img> 标签并保持滚动效果

标签 javascript html css seo

我想为我网站上的图片添加 alt 标签以改进 SEO。问题是我使用 CSS background-image: url(...) 嵌入它们。

它创建了所需的滚动效果(见下文),但不利于 SEO。

当前代码:

.text {
  margin: 200px 20px;
}
.image-background {
  background-attachment: fixed;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100%;
  display: block;
  height: 800px;
  margin-bottom: 150px;
  margin-left: -1500px;
  margin-right: -1500px;
  margin-top: 150px;
  width: 3500px;
}
.image1 {
  background-image: url(https://i.ytimg.com/vi/tntOCGkgt98/maxresdefault.jpg);
}
.image2 {
  background-image: url(http://media1.santabanta.com/full1/Animals/Cats/cats-149a.jpg);
}
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class='image-background image1'></div>
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class='image-background image2'></div>
<div class='text'>
  Lorem ipsum dolores...
</div>

问题是:如何添加 <img>带有 alt 的标签不破坏视觉外观的属性?

编辑:

我尝试将 与 css position:fixed 一起使用,但无法让它很好地工作有多个图像 ( my broken jsfiddle here )。

编辑 2:

这些图像是网站内容的一部分,不是布局。他们应该使用 alt 标签,我并不是想以“糟糕”的方式填充更多关键字。我最初把它们作为背景来达到视觉效果。现在我想修正错误,但不改变网站的外观。 我在说about my photos on this blog .

编辑 3:

我不想在这里使用 CSS。任何代码修改、JS 库或几乎任何东西都可以!

最佳答案

方法一

此方法不会改变图像的可见性,因此我认为完全没有关于 SEO 的问题。但它更复杂,并且有一个警告,即每次只能出现一个图像。因此文本的 div 必须填满整个屏幕,从而产生较大的填充。

$(function(){
  var texts = $('.text');
  var oldY = 0;
  
  $(document).scroll(function(){
    var y = window.scrollY;
    
    texts.each(function(){
      var text = $(this);
      
      if(y >= text.offset().top)
        text.next().addClass('active');
      else
        text.next().removeClass('active');
    });
  });
});
body{
  padding: 0;
  margin: 0;
}

.text{
  padding: 20px;
  margin: 0 0 600px;
  position: relative;
  z-index: 3;
  background-color: #fff;
  min-height: 100vh;
  display: flex;
  align-items: center;
}
.background-img img{
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
}
.background-img.active img{
  z-index: 2;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class="background-img active">
  <img src="https://i.ytimg.com/vi/tntOCGkgt98/maxresdefault.jpg" alt="Image 1">
</div>
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class="background-img">
  <img src="http://media1.santabanta.com/full1/Animals/Cats/cats-149a.jpg" class="background-img" alt="Image 2">
</div>
<div class='text'>
  Lorem ipsum dolores...
</div>

方法二

这个比较简单,说实话和你原来的代码差不多。不同之处在于,一旦页面加载,图像就会被隐藏,然后复制为其父 div 的背景图像。优点是可以同时看到多张图片,效果更好。

$(function(){
  $('.background-img img').each(function(){
    var img = $(this).hide();
    img.parent().css('background-image', 'url(' + img.prop('src') + ')');
  });
});
body{
  padding: 0;
  margin: 0;
}

.text{
  padding: 200px 20px;
  position: relative;
  z-index: 3;
  background-color: #fff;
}

.background-img{
  height: 400px;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class="background-img">
  <img src="https://i.ytimg.com/vi/tntOCGkgt98/maxresdefault.jpg" alt="Image 1">
</div>
<div class='text'>
  Lorem ipsum dolores...
</div>
<div class="background-img">
  <img src="http://media1.santabanta.com/full1/Animals/Cats/cats-149a.jpg" class="background-img" alt="Image 2">
</div>
<div class='text'>
  Lorem ipsum dolores...
</div>

关于javascript - 将 css background-image : url(. ..) 替换为 <img> 标签并保持滚动效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39683354/

相关文章:

javascript - 此代码块的 eval() 函数的替代方案

css - 对齐 div 中的元素 - 奇怪的行为

html - iframe 内的图片需要授权

javascript - 如何在不影响其他元素的情况下使用bootstrap collapse?

css - 考虑到 flex 属性不是分层的,在嵌套 flex 布局中的所有祖先节点上设置 "flex:1"或 "flex-grow:1"的解释?

javascript:捕获当前页面上的任何点击事件并阻止导航?

javascript - 如何阅读 Javascript 文档?

html - 如何将 img 的宽度百分比包裹在特定的 div 宽度中?

javascript - 基于其位置的可拖动 DIV 样式

javascript - 如何使用 Jquery 如何更改 aria-expanded ="false"dom 元素的一部分(Bootstrap)?