javascript - Blogger,如何更改 'Random' 帖子的缩略图大小?

标签 javascript html widget blogger

Blogger,如何调整随机帖子的外部图像

randompoststhumb = entry.content.$t.match(/\<img.+src\=(?:\"|\')(.+?)(?:\"|\')(?:.+?)\>/)[1];

比如在 blogger 中使用 'resizeImage' 函数 includable expr:bellow:

<b:includable id='feedPostImage'>
  <div class='snippet-thumbnail-container'>
	  <a expr:href='data:post.link ?: data:post.url'>
		<img expr:src='resizeImage(data:post.featuredImage, 280, &quot;280:152&quot;)'/>
	  </a>
  </div>
</b:includable>

<div id='random-posts'>
<script type='text/javaScript'>
var randomposts_number = 10;
var randomposts_chars = 0;
var randomposts_details = 0;
var randomposts_comments = 'Comments';
var randomposts_commentsd = 'Comments Disabled';
var randomposts_current = [];
var total_randomposts = 0;
var randomposts_current = new Array(randomposts_number);

function randomposts(json) {
    total_randomposts = json.feed.openSearch$totalResults.$t
}
document.write('<script type=\"text/javascript\" src=\"/feeds/posts/default?alt=json-in-script&max-results=0&callback=randomposts\"><\/script>');

function getvalue() {
    for (var i = 0; i < randomposts_number; i++) {
        var found = false;
        var rndValue = get_random();
        for (var j = 0; j < randomposts_current.length; j++) {
            if (randomposts_current[j] == rndValue) {
                found = true;
                break
            }
        };
        if (found) {
            i--
        } else {
            randomposts_current[i] = rndValue
        }
    }
};

function get_random() {
    var ranNum = 1 + Math.round(Math.random() * (total_randomposts - 1));
    return ranNum
};
</script>
<script type='text/javaScript'> 
function random_posts(json) {
    for (var i = 0; i < randomposts_number; i++) {
      var entry = json.feed.entry[i];
      var randompoststitle = entry.title.$t;
		
        if ('content' in entry) {
            var randompostsnippet = entry.content.$t
        } else {
            if ('summary' in entry) {
                var randompostsnippet = entry.summary.$t
            } else {
                var randompostsnippet = "";
            }
        }
        randompostsnippet = randompostsnippet.replace(/<[^>]*>/g, "");
        if (randompostsnippet.length < randomposts_chars) {
            var randomposts_snippet = '<div class="random-summary">' + randompostsnippet + '</div>';
        } else {
            randompostsnippet = randompostsnippet.substring(0, randomposts_chars);
            var whitespace = randompostsnippet.lastIndexOf(" ");
            var randomposts_snippet = randompostsnippet.substring(0, whitespace) + "&#133;";
            randomposts_snippet = '<div class="random-summary">' + randomposts_snippet + '</div>';
        }
	  
        for (var j = 0; j < entry.link.length; j++) {
            if ('thr$total' in entry) {
                var randomposts_commentsnum = entry.thr$total.$t + ' ' + randomposts_comments
            } else {
                randomposts_commentsnum = randomposts_commentsd
            } 
			if (entry.link[j].rel == 'alternate') {
                var randompostsurl = entry.link[j].href;
                var randomposts_date = entry.published.$t;
				if ('media$thumbnail' in entry) 
				{
					var randompoststhumb = entry.media$thumbnail.url
				} 
				else if ( entry.content.$t.match(/\<img.+src\=(?:\"|\')(.+?)(?:\"|\')(?:.+?)\>/))
				{
				  // how to resize this external image ?
				     randompoststhumb = entry.content.$t.match(/\<img.+src\=(?:\"|\')(.+?)(?:\"|\')(?:.+?)\>/)[1];
				  // like using 'resizeImage' function in blogger includable expr:
				  // randompoststhumb = resizeImage(randompoststhumb, 280, &quot;280:152&quot;)
				} else {
					randompoststhumb = "http://3.bp.blogspot.com/-5SoVe1K6JSk/Utl0OOmucAI/AAAAAAAAF6E/hQghgD_EJdQ/s1600/no_thumb.png"
				}
            }
        }
        document.write('<div class="randomPost">');
        document.write('<a href="' + randompostsurl + '" rel="nofollow">' + '<span class="imgf"><span src="' + randompoststhumb + '"></span></span>' + randompoststitle + '</a>');
        if (randomposts_details) {
            document.write('<span><div class="random-info">' + randomposts_date.substring(8, 10) + '.' + randomposts_date.substring(5, 7) + '.' + randomposts_date.substring(0, 4) + ' - ' + randomposts_commentsnum) + '</div></span>'
        }
        if (randomposts_chars) {
			document.write(randomposts_snippet);
        }
		document.write('</div>');
    }
}
getvalue();
for (var i = 0; i < randomposts_number; i++) {
    document.write('<script type=\"text/javascript\" src=\"/feeds/posts/default?alt=json-in-script&start-index=' + randomposts_current[i] + '&max-results=1&callback=random_posts\"><\/script>')
}
</script>
</div>

最佳答案

在这种情况下,使用 Google 的即时图像大小调整服务是更好的方法。正如 Carlo Zottmann ( https://stackoverflow.com/users/333272/carlo-zottmann ) 在 https://czm.io/posts/2013/04/google-image-resizer/ 中所解释的那样,API如下-

Base URL

https://images1-focus-opensocial.googleusercontent.com/gadgets/proxy

Parameters:

  • url: original image URL

  • container: must be “focus”

  • refresh: time (in seconds) to cache it on G’s servers

  • resize_w: width in pixels

  • resize_h: height in pixels You can either specify both

  • resize_* parameters or just one.

您将需要更改以下代码块 -

// how to resize this external image ?
randompoststhumb = entry.content.$t.match(/\<img.+src\=(?:\"|\')(.+?)(?:\"|\')(?:.+?)\>/)[1];
// like using 'resizeImage' function in blogger includable expr:

与-

// how to resize this external image ?
randompoststhumb = entry.content.$t.match(/\<img.+src\=(?:\"|\')(.+?)(?:\"|\')(?:.+?)\>/)[1];
randompoststhumb = 'https://images1-focus-opensocial.googleusercontent.com/gadgets/proxy?url=' + randompoststhumb + '&container=focus&resize_w=300&resize_h=300&refresh=2592000';
// like using 'resizeImage' function in blogger includable expr:

由于我们不能在此用例中使用 resizeImage 运算符,您也可以使用相同的 API 来调整上传到 Blogger 的图像的大小。您将需要更换 -

var randompoststhumb = entry.media$thumbnail.url

与-

var randompoststhumb = entry.media$thumbnail.url.replace("s72-c", "s0").replace("/default.jpg","/hqdefault.jpg");
randompoststhumb = 'https://images1-focus-opensocial.googleusercontent.com/gadgets/proxy?url=' + randompoststhumb + '&container=focus&resize_w=300&resize_h=300&refresh=2592000';

由于这是一个未记录的 API,我们无法确定它在未来的可用性(因为这与将于 2019 年 4 月关闭的 Google+ 社交网络有关)。即时图像大小调整服务有多种选择,既有付费的(如 https://kraken.io/docs/image-resizing )也有自托管的(如 https://github.com/jimmynicol/image-resizer )

关于javascript - Blogger,如何更改 'Random' 帖子的缩略图大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54834482/

相关文章:

javascript - JQuery slider : Calling function without ID but with the object

JavaScript 渲染逻辑 : Horizontal Dynamic Booking Calendar

html - 将图像数据设置为要在 HTML 伪元素中使用的自定义 ISO 字符

html - 使所有链接颜色为灰色

qt - 如何调整 Qt 小部件的大小?

javascript - 设置变量值的简写

javascript - 如何在webkit中获取多列布局中的列数

python - 如何从 HTML 标题中获取引用的字符串?

widget - 如何在 Flutter 中禁用默认的 Widget 飞溅效果?

widget - 如何使用 IPython Widgets 让一个参数的可能值依赖于另一个参数?