Youtube订阅——解决在弹窗内使用Youtube订阅按钮高度显示不全的问题

背景:公司网站业务在作海外营销网站,为了配合营销工做,前端总要在各类地方添加各类社媒订阅(摊手.jpg);最近遇到的是在弹窗内展现公司的Youtube帐号的订阅按钮。前端

理想:我想使用的例子是这样的:bootstrap

 

现状:可是当我实际使用的时候,却只显示了一半,以下图:api

 

 

 解决问题思路:浏览器

1. 起初,我觉得是加载的外部js先执行的缘由,因此将script加了defer属性(延迟执行),发现没有任何效果;dom

2. 其次,仍是老老实实去查了官方文档https://developers.google.com/youtube/subscribe/reference函数

官方api提供了不少功能的go/render方法,动态渲染订阅按钮或其余功能:学习

 

 

 

 3. 最后我在bootstrap弹窗加载完的钩子函数中调用了gapi.ytsubscribe.render方法,实现了功能,代码以下:网站

<!--#modal-sample-lg-->

<script src="https://apis.google.com/js/platform.js"></script>
<div id="yt-button-container-render" class="g-ytsubscribe"></div>
<!--#modal-sample-lg-->
 <script> $(function() { var acount = 0; $('#modal-sample-lg').on('shown.bs.modal', function () { // 只加载一次,避免闪烁 if(acount === 0) { var container = document.getElementById('yt-button-container-render'); var options = { 'channelid': 'UCv1uPumg4LFFC9qwYWKyxhw', 'layout': 'full', 'count': 'hidden', }; gapi.ytsubscribe.render(container, options); acount++; } }) }) </script>

 

最后:将go实现的代码放到下面:google

<!-- modal-sample-lg callback begin -->
<!-- #modal-sample-lg -->
<script src="https://apis.google.com/js/platform.js"></script>
<div id="yt-button-container-go"></div>
<!-- #modal-sample-lg -->
<script>
    $('#modal-sample-lg').on('shown.bs.modal', function () {
        var container = document.getElementById('yt-button-container-go');
        var div = '<div class="g-ytsubscribe" data-channelid="UCv1uPumg4LFFC9qwYWKyxhw" data-layout="full" count="hidden"></div>'
        container.innerHTML = div;
        gapi.ytsubscribe.go(container);
    })
</script>
<!-- modal-sample-lg callback end -->

 

总结:spa

1. 在过程当中也尝试了方法,好比说使用默认的订阅按钮(不知足需求),或者说将引入的官方js放到最后,结果都没有达到目的;

2. 究其缘由,默认的订阅按钮是页面加载完后就已经加载结束了,而data-layout="full",表示高度和宽度是由内容撑开的,在初始化的时候由js动态加载的logo图片尚未加载到dom树中,高度没有被撑开,订阅按钮显示不完整;

3. 想到这里,若给订阅按钮最小高度,应该也是能够的(刚去验证了一下,果真是能够的,可是必须使用px,不能够使用rem,由于订阅按钮是使用iframe承载的......)

4. 浏览器渲染机制博大精深,继续学习~

4. 虽然Youtube订阅国内不经常使用,可是记录一下~