手把手教你如何在华为云服务器上部署一个自己的弹幕网站!
【摘要】 从零代码开始,10分钟快速开发一个可以发送弹幕的网站,并将其部署在华为云服务器上;学完本期教程,将可以知道如何使用Nginx、如何将自己的网站部署到云服务器上,还可以免费学习WEB前端全栈教程,各位小伙伴们一起来学习吧~
开发思路
首先是让弹幕的随机高度出现,这个计算方法是:最大高度=屏幕的高度-发送div的高度-弹幕本身的高度,范围就是 0-最大高度了,弹幕总是从右往左移动,所以出现最右侧的位置计算方法是:最右侧位置=屏幕的宽度-弹幕本身的宽度;接下来就是设置随机颜色,颜色按照‘#aabbcc’这种格式,利用Math.random()随机数生成;最后是弹幕的发送,首先是获取输入框中的值,然后新创建一个div,并设置随机颜色、位置等属性,调用init() 函数。
总结如下步骤:
1、获取弹幕对象:随机高度、初始化颜色
2、水平期间设置范围:浏览器宽度-弹幕对象的高度
3、移动功能函数:定时器 setInterval
4、实现用户发表弹幕
用到的知识点
1、首先页面搭建,就是这些东西是如何摆放的——html+css布局
2、弹幕字体的位置和样色设置——css样式
3、可以输入文字然后点击可以发送弹幕——按钮的点击事件
4、字体可以旋转——css动画
5、弹幕字体可以从右往左滑动——js控制字体对象的style属性
代码块
style代码
<style type="text/css">
* {
margin: 0;
padding: 0;
}
.screen {
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
}
.send {
width: 100%;
height: 76px;
background: #333;
position: absolute;
bottom: 0;
left: 0;
text-align: center;
line-height: 76px;
}
.send .s_txt {
width: 600px;
height: 36px;
border: 0;
border-radius: 3px 0 0 3px;
font-size: 16px;
line-height: 36px;
}
.send .s_sub {
width: 100px;
height: 37px;
background: #65c33d;
border: 0;
font-size: 14px;
color: #fff;
border-radius: 0 3px 3px 0;
cursor: pointer;
}
.send .s_sub:hover {
background: #3eaf0e;
}
.screen div {
position: absolute;
top: 76px;
left: 0;
font-size: 22px;
color: red;
}
.magictime {
animation-duration: 1s;
animation-name: magictime;
}
@keyframes magictime {
0% {
opacity: 0;
transform-origin: 100% 0;
transform: scale(0, 0) rotate(360deg) translateY(100%);
}
30% {
transform-origin: 100% 0;
transform: scale(0, 0) rotate(360deg) translateY(100%);
}
100% {
opacity: 1;
transform-origin: 0 0;
transform: scale(1, 1) rotate(0deg) translateY(0);
}
}
</style>
弹幕滚动div代码
<div class="screen">
<div>这是一条弹幕!</div>
<div>这是另一条弹幕!</div>
<div>老黄最帅~~~</div>
<div>没错,这又是一条弹幕!</div>
<div>这里都是弹幕</div>
<div>前方高能!!!</div>
</div>
发送弹幕div代码
1234 | < div class = "send" > < input type = "text" class = "s_txt" /> < input type = "button" id = "send_sub" value = "发表评论" class = "s_sub" /> </ div > |
javascript逻辑代码
<script>
var oShowList = document.querySelectorAll('.screen div')
var oShow = document.querySelector('.screen')
var oSend = document.querySelector('.send')
var oText = document.querySelector('.s_txt')
var oBtn = document.querySelector('#send_sub')
oBtn.onclick = function () {
var oDiv = document.createElement('div')
oDiv.innerHTML = oText.value;
oDiv.className = 'magictime';
oShow.appendChild(oDiv)
init(oDiv)
oText.value = ''
}
for (var i = 0; i < oShowList.length; i++) {
init(oShowList);
}
function init(obj) {
var screenHeight = document.documentElement.clientHeight;//获取浏览器高度
var screenWidth = document.documentElement.clientWidth;//获取浏览器宽度
var sendHeight = oSend.clientHeight;
var maxTop = screenHeight - sendHeight - obj.clientHeight;
var maxLeft = screenWidth - obj.clientWidth;
obj.style.top = Math.random() * maxTop + 'px'
obj.style.left = maxLeft + 'px'
obj.style.color = randomColor()
move(obj, maxLeft)
}
function randomColor() {
var color = '#';
for (var i = 0; i < 6; i++) {
color += Math.floor(Math.random() * 16).toString(16)
}
return color;
}
function move(obj, maxLeft) {
maxLeft -= 3;
if (maxLeft > -obj.clientWidth) {
obj.style.left = maxLeft + 'px'
requestAnimationFrame(function () {
move(obj, maxLeft)
});
} else {
oShow.removeChild(obj)
}
}
</script>
安装部署
首先领取一个月的免费服务器,如果通过我这里注册,还可以领取200元的代金券,可多购买两个月的服务器 领域地址 ,然后系统选择Ubuntu 18.04 server 64bit,设置密码,领取后按照一下步骤初始化:
修改一下安全组,点击安全组,更改安全组,把入方向的勾选上
登录
也可以通过xshell登录,用户名为root,密码为之前设置的,如果忘了可以选择重置系统
安装nginx
配置nginx
好啦,以上就是开发一个可以发送弹幕网站的完整过程了,如果有什么疑问,欢迎在下面留言告诉老黄~
阅读原文:https://bbs.huaweicloud.com/forum/thread-61047-1-1.html
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
wangshushu2020/07/01 07:36:571楼编辑删除举报
szaxr2020/07/15 02:13:502楼编辑删除举报