这篇文章给大家分享的是有关django2如何使用iframe标签完成网页内嵌播放b站视频功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
1.选择视频网站进行视频引用:
1.爱奇艺的视频加广告加得简直丧心病狂,像老太太的裹脚布又臭又长,垃圾,不用!
2.腾讯视频的视频也加广告,虽然广告没有那么长,但是很阴险的是,如果视频超过十几分钟,就会无法在引用视频的网站播放,被强制要求转去腾讯视频才可以看,简直狼子野心,垃圾中的垃圾,不用!
3.bilibili,也就是传说中的b站,不但视频没有广告(引导型广告还是有的,但是不影响观看,不是那种不看完广告不让看视频的霸王硬广),没有玩儿阴的强制跳转去他家网站,还高清无码有弹幕,选b站!
2.实际操作:
1.在template目录下的index.html中加入跟视频引用相关的代码:
<!--视频 S-->
<div class="videoCon">
<div class="name" >新闻公告</div>
<div class="videoF">
<!--这里填入从b站随机挑选一个视频,然后获取的引用代码-->
<iframe src="//player.bilibili.com/player.html?aid=24841101&cid=41877807&page=1"
scrolling="no" border="0" frameborder="no" framespacing="0" allowfullscreen="true">
</iframe>
<!---->
</div>
</div>
<!--视频 E-->
2.获取b站的视频引用相关代码(随机挑选一个b站视频,进入视频播放页)
3.django网页中的效果图
3.跟django后端结合,动态的嵌入不同视频
1.在models.py中(一般嵌入代码长度不会超过300,在150——300之间)
class Bili(models.Model):
'''新闻相关视频'''
new=models.ForeignKey(News,verbose_name='新闻公告',on_delete=models.CASCADE)
is_topline=models.BooleanField(default=False,verbose_name='是否是头条')
bili=models.CharField(verbose_name='视频嵌入代码',max_length=300)
add_time = models.DateTimeField(default=datetime.now, verbose_name='添加时间')
class Meta:
verbose_name = '新闻相关视频'
verbose_name_plural = verbose_name
def __str__(self):
return self.new.title
打开Terminal终端,执行数据更新命令:
python manage.py makemigrations
python manage.py migrate
2.在adminx.py中注册
import xadmin
from .models import News,Bili
class NewsAdmin(object):
list_display = ['title', 'img','click_num','add_time']
search_fields = ['title', 'img','click_num',]
list_filter = ['title', 'img','click_num','add_time']
style_fields={'context':'ueditor'}
#注册代码
class BiliAdmin(object):
list_display = ['new', 'is_topline']
search_fields = ['new', 'is_topline']
list_filter =['new', 'is_topline']
xadmin.site.register(News, NewsAdmin)
#注册代码
xadmin.site.register(Bili, BiliAdmin)
3.可以在xadmin后台进行多个视频嵌入代码的填入
随机在b站找的三个视频的嵌入代码:
<iframe src="//player.bilibili.com/player.html?aid=24687507&cid=41510047&page=1" scrolling="no"
border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
<iframe src="//player.bilibili.com/player.html?aid=22025564&cid=36402353&page=1" scrolling="no"
border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
<iframe src="//player.bilibili.com/player.html?aid=17766502&cid=29007139&page=1" scrolling="no"
border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
4.在views.py中:
from .models import News,Bili
class NewView(View):
"""新闻公告详情"""
def get(self,request,new_id):
new=News.objects.filter(id=new_id).first()
new.click_num+=1
# 根据新闻公告的不同,显示与之关联的视频
bili=Bili.objects.filter(new=new).last()
new.save()
return render(request,'news-base.html',{'new':new,'bili':bili})
class IndexView(View):
"""首页"""
def get(self,request):
all_news=News.objects.all().order_by('-add_time')
p = Paginator(all_news, 20)
page = request.GET.get('page', 1)
try:
news = p.page(int(page))
except PageNotAnInteger:
news = p.page(1)
#首页播放被标记为头条的最后一部视频
bili=Bili.objects.filter(is_topline=True).last()
return render(request,'index.html',{'news':news,'bili':bili})
5.改写Template目录下的index.html(首页)和new-base.html(新闻模板页)
index.html
<!--视频 S-->
<div class="videoCon">
<div class="name" >新闻公告</div>
<div class="videoF">
{{ bili.bili|safe }}
</div>
</div>
<!--视频 E-->
new-base.html
<!--视频 S-->
<div class="videoCon">
<div class="name" >{{ new.title }}</div>
<div class="videoF">
{{ bili.bili|safe }}
</div>
</div>
<!--视频 E-->
感谢各位的阅读!关于“django2如何使用iframe标签完成网页内嵌播放b站视频功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!