Cách tạo biểu tượng theo label hiển thị trong ảnh

Lọc lấy label trong vòng lặp thay thế bằng biểu tượng hiển thị trong ảnh bài viết tại trang chỉ mục

Để thêm phần sinh động, tạo điểm nhấn cho ảnh bài viết ngoài trang chỉ mục, một số trang web đặc biệt là những trang tin tức thường thiết kế thêm các biểu tượng nằm bên trong ảnh hiển thị góc trái phải trên dưới của ảnh giúp người đọc biết bài viết đó thuộc chuyên mục nào chẳng hạn như video, photo. Tóm gọn lại là thay thế văn bản label bằng biểu tượng hiển thị.

Sử dụng điều kiện trong vòng lặp lọc lấy label thay thế bằng class sau đó design css cho class để cho ra biểu tượng. Lấy ví dụ mình sẽ lọc label lấy ra hai chuyên mục video và photo sau để chèn vào ảnh, mình sẽ chèn như sau:

blogger thumbnail icon
Biểu tượng video và photo hiển thị góc phải ảnh bài viết

Đầu tiên mình sẽ đi tìm element của ảnh trong theme, giả sử nó có một đoạn xml trong theme như sau:

<b:tag class='post_thumb' name='div'>
  <b:tag expr:title='data:post.title' name='a'>
    <b:attr expr:value='data:post.link ? data:post.link : data:post.url.canonical' name='href'/>
      <b:if cond='data:post.featuredImage.isYouTube'>
        <img class='lazyload' expr:alt='data:post.title' expr:data-src='resizeImage(data:view.featuredImage.youtubeMaxResDefaultUrl, 320, &quot;16:9&quot;)' src=''/>
      <b:elseif cond='data:post.featuredImage'/>
        <img class='lazyload' expr:alt='data:post.title' expr:data-src='resizeImage(data:post.featuredImage, 320, &quot;16:9&quot;)' src=''/>
      <b:else/>
        <img class='lazyload' data-src='https://4.bp.blogspot.com/-00O66C-eBQs/W0IcokXSnOI/AAAAAAAAL_k/g4KtDm7SkQsoe7_G0vZ_C_nU0Gf_-kyVQCLcBGAs/s320/safe_image.png' expr:alt='data:post.title' src=''/>
      </b:if>
  </b:tag>
</b:tag>

Đọc thêm: Thẻ dữ liệu hình ảnh trong tiện ích Bài đăng trên Blog version 2

Mình sẽ thêm 2 label video và photo thay thế bằng class thumbnail_video và thumbnail_photo cùng với class post_thumb

<b:tag class='post_thumb' name='div'>
  <b:loop values='data:post.labels' var='label'>
    <b:if cond='data:label.name eq "video"'>
      <b:class name='thumbnail_icon thumbnail_video'/>
    <b:elseif cond='data:label.name eq "photo"'/>
      <b:class name='thumbnail_icon thumbnail_photo'/>
    </b:if>
  </b:loop>
  <b:tag expr:title='data:post.title' name='a'>
    <b:attr expr:value='data:post.link ? data:post.link : data:post.url.canonical' name='href'/>
      <b:if cond='data:post.featuredImage.isYouTube'>
        <img class='lazyload' expr:alt='data:post.title' expr:data-src='resizeImage(data:view.featuredImage.youtubeMaxResDefaultUrl, 320, &quot;16:9&quot;)' src=''/>
      <b:elseif cond='data:post.featuredImage'/>
        <img class='lazyload' expr:alt='data:post.title' expr:data-src='resizeImage(data:post.featuredImage, 320, &quot;16:9&quot;)' src=''/>
      <b:else/>
        <img class='lazyload' data-src='https://4.bp.blogspot.com/-00O66C-eBQs/W0IcokXSnOI/AAAAAAAAL_k/g4KtDm7SkQsoe7_G0vZ_C_nU0Gf_-kyVQCLcBGAs/s320/safe_image.png' expr:alt='data:post.title' src=''/>
      </b:if>
  </b:tag>
</b:tag>

Đọc thêm: Cách sử dụng thẻ b:attr và b:class trong blogspot

CSS cho 2 biểu tượng video và photo, mình sử dụng background-image


.thumbnail_icon:after {
    position: absolute;
    content: " ";
    display: inline-block;
    background-image: url(https://cdn.jsdelivr.net/gh/thietkeblogspot/images/thumbnail_icon.png);
    background-color: rgba(0,0,0,.5);
    right: 5px;
    bottom: 5px;
    width: 23px;
    height: 23px;
    border-radius: 15px;
    background-size: 100px 4250px;
}
.thumbnail_video:after {
    background-position: 0 -750px;
}
.thumbnail_photo:after {
    background-position:0 -700px;
}
.thumbnail_video:hover:after,.thumbnail_photo:hover:after {
    background-color:rgba(0,0,0,.7);
}
.thumbnail_video:hover:after {
    background-position:-50px -750px;
}
.thumbnail_photo:hover:after {
    background-position:-50px -700px;
}
Thêm đánh giá

Trở thành người đầu tiên bình luận cho bài viết này!