Posting Auto Read-More Tanpa JavaScript
Posting ini sekaligus sebagai sanggahan dari pernyataan Saya mengenai tidak adanya tag khusus dari Blogger untuk memproduksi ringkasan artikel pada Optimasi Thumbnail pada Auto Read-More Link dan Widget Blogger
Versi posting auto read-more link yang satu ini adalah murni menggunakan tag data
dari Blogger untuk mengambil ringkasan artikel dan thumbnail posting. Kita akan menggunakan ke dua elemen ini untuk menyisipkan ringkasan dan gambar:
Mengambil Ringkasan Posting
<data:post.snippet/>
Mengambil Thumbnail Posting
<img expr:src='data:post.thumbnailUrl'/>
Selama ini Saya tidak menyadarinya, tapi jika kita melihat isi dari widget Posting Populer, maka kita akan menemukan kedua data
tersebut di dalamnya (sedikit berbeda pada data:post.thumbnailUrl
). Mereka berdua digunakan untuk menampilkan ringkasan artikel sebanyak 100 karakter dan thumbnail berukuran 72 × 72 piksel seperti yang biasanya kita lihat pada widget Posting Populer bawaan dari Blogger - Referensi
<!-- (4) Show snippets and thumbnails -->
<div class='item-content'>
<b:if cond='data:post.thumbnail'>
<div class='item-thumbnail'>
<a expr:href='data:post.href' target='_blank'>
<img alt='' expr:height='data:thumbnailSize' expr:src='data:post.thumbnail' expr:width='data:thumbnailSize'/>
</a>
</div>
</b:if>
<div class='item-title'><a expr:href='data:post.href'><data:post.title/></a></div>
<div class='item-snippet'><data:post.snippet/></div>
</div>
<div class='clear' style='clear: both;'/>
Jika Anda saat ini telah memakai versi auto read-more link script, Anda bisa dengan mudah memodifikasinya. Pada formulir HTML Temlpate, temukan kode ini:
<div expr:id='"summary" + data:post.id'><data:post.body/></div>
<script>createSummaryAndThumb("summary<data:post.id/>");</script>
Ganti menjadi seperti ini:
<b:if cond='data:post.thumbnailUrl'>
<a expr:href='data:post.url'><img class='post-thumbnail' alt='thumbnail' expr:src='data:post.thumbnailUrl'/></a>
<b:else/>
<a expr:href='data:post.url'><img class='post-thumbnail' alt='thumbnail' src='http://reader-download.googlecode.com/svn/trunk/images/no-image-72x72.png'/></a>
</b:if>
<div class='post-snippet'><data:post.snippet/></div>
Setelah itu temukan kode ini:
]]></b:skin>
Letakkan kode CSS ini di atasnya untuk mengatur posisi thumbnail:
.post-thumbnail {
width:72px;
height:72px;
float:left;
margin:2px 10px 0 0;
}
Terakhir, Anda bisa membuang script auto read-more link yang biasanya terletak di atas </head>
Klik Simpan Template.
Jika posting Anda masih berupa posting biasa, carilah kode ini:
<data:post.body/>
Ganti dengan kode ini:
<b:if cond='data:blog.pageType != "static_page"'>
<b:if cond='data:blog.pageType != "item"'>
<b:if cond='data:post.thumbnailUrl'>
<a expr:href='data:post.url'><img class='post-thumbnail' alt='thumbnail' expr:src='data:post.thumbnailUrl'/></a>
<b:else/>
<a expr:href='data:post.url'><img class='post-thumbnail' alt='thumbnail' src='http://reader-download.googlecode.com/svn/trunk/images/no-image-72x72.png'/></a>
</b:if>
<div class='post-snippet'>
<data:post.snippet/>
</div>
<div class='rm-button-wrap'>
<a class='button' expr:href='data:post.url'>Baca Selengkapnya</a>
</div>
</b:if>
</b:if>
<b:if cond='data:blog.pageType == "item"'>
<data:post.body/>
</b:if>
<b:if cond='data:blog.pageType == "static_page"'>
<data:post.body/>
</b:if>
Klik Simpan Template.
Masalah Interpretasi Tag HTML
<data:post.snippet/>
memiliki sikap yang tidak lazim jika dilihat dari segi perannya di dalam menampilkan ringkasan artikel. Dia akan memparse semua kode HTML yang pernah kita ketik di dalam posting menjadi apa adanya. Sehingga hal-hal aneh semacam ini mungkin akan Anda alami terutama jika Anda memiliki posting dengan kumpulan kode HTML di dalamnya:
Blogger sepertinya sudah memperbaiki masalah ini.
Kita bisa saja menggunakan JavaScript untuk menghilangkan semua tag HTML di dalamnya, tapi di sini Saya ingin merealisasikan isi artikel sesuai dengan judulnya (tanpa JavaScript). Jadi untuk kasus ini Saya akan menggunakan CSS Pseudo-Element.
Kita tidak akan meletakkan data:post.snippet
sebagai elemen apa adanya seperti halnya saat kita menuliskan kode <data:post.snippet/>
, tapi kita akan memasukkannya ke dalam atribut seperti ini:
<div class='post-snippet' expr:data-snippet='data:post.snippet'></div>
Dengan cara di atas, maka deskripsi posting akan tersimpan di dalam atribut data-snippet
. Dan untuk menampilkan nilai atribut tersebut sebagai teks, kita bisa menggunakan CSS Pseudo-Element :before
atau :after
seperti ini:
.post-snippet:before {
content:attr(data-snippet);
}