B站后端java_GitHub - javalovelinux/bilibili-vue: 前端vue+后端koa,全栈式开发bilibili首页...

这是一个使用vue2、vuex、koa2全栈开发的B站首页项目。前端包括vue、webpack、ES6/7、stylus和nginx,后端为koa2。项目分为多个组件,通过vuex进行状态管理,使用axios处理网络请求,包含丰富的动画效果,并进行了性能优化。后端部署使用pm2,前端通过webpack打包并配置nginx。
摘要由CSDN通过智能技术生成

技术栈

前端:vue2 + vuex + webpack + ES6/7 + stylus + nginx

后端:koa2

项目运行

如何运行

运行前请先安装nodejs

clone项目到本地

git clone https://github.com/lybenson/bilibili-vue.git

前端运行

cd bilibili-vue

npm install

npm run dev

后端运行

cd bilibili-vue/bilibili-api

npm install

npm run dev

为了确保运行正确,请先运行后端服务。再运行前端,之后访问 http://localhost:8080

组件

根据首页的各模块的功能不同,划分出了共20多个可复用的组件。具体请看下方

├── banner //轮播组件

│   ├── Banner.vue

│   └── BannerItem.vue

├── common // 公共组件

│   ├── BHeader.vue

│   ├── BMenu.vue

│   ├── BMenuItem.vue

│   ├── PostMaterial.vue

│   ├── Search.vue

│   └── TopContainer.vue

├── content // 主内容组件

│   └── BContent.vue

├── contentRow // 单个分类的组件

│   ├── BContentRow.vue

│   ├── BRowBody.vue

│   ├── BRowHead.vue

│   ├── BRowItem.vue

│   ├── BRowRank.vue

│   └── BRowRankBody.vue

├── contentTop // 页面顶部组件

│   ├── BContentTop.vue

│   └── BContentTopItem.vue

├── live //直播所在的组件

│   ├── BLive.vue

│   ├── BLiveItem.vue

│   ├── BLiveRank.vue

│   └── BLiveRankItem.vue

├── nav //右侧导航条组件

│   ├── BNavSide.vue

│   └── smooth-scroll.js

└── promote // 推广组件

├── BPromote.vue

└── BPromoteItem.vue

组件的原则就是尽量将复杂的UI布局划分成单个小的UI组件,逻辑处理也被划分成更多的单个小的逻辑。数据流动采用的单向数据流动。子组件的数据更多的是来自于父组件,父组件的数据主要是其本身发起的ajax请求。本项目中ajax请求库使用的是axios。

状态管理

目前的状态管理采用vuex。由于vuex可以分多个子module。所以在不同模块下单独维护一份状态,同时对于一些公共的状态,比如发起网络请求的requesting,错误时的状态error则保存在根状态中,之后可以通过子模块中的rootState.requesting获取来赋值。

在子模块中发送网络请求获取数据是一个异步的过程,所以将网络请求放在actions。每次发起网络需要经历下面的步骤

请求中

rootState.requesting = true //请求状态更新为true,表示请求中

commit(TYPE.XX_REQUEST) // 发送同步操作,请求中的数据处理

请求成功

rootState.requesting = false //请求状态更新为false,表示请求结束

commit(TYPE.XX_SUCCESS, response) //发送同步操作,处理请求成功后数据

请求失败

rootState.requesting = false //请求状态更新为false,表示请求结束

rootState.error = error

commit(TYPE.XX_FAILURE, error) //发送同步操作,处理请求失败

动画

B站首页充斥着大量的动画效果。目前动画使用的主要有三种方式:

以hover效果触发。

通过js触发的效果,如点击轮播图的原点时,主要通过设置css属性transition: .2s;,再通过js 设置css属性this.$refs.banner.style.marginLeft = left。

通过vue提供的动画方式。

样式

样式文件使用的是stylus,暂未使用任何vue现成的UI组件。需要安装stylus-loader, stylus,由于vue-cli中的webpack已经配置好了stylus了,所以只需要安装就可以了。

npm install stylus-loader --save-dev

npm install stylus --save-dev

性能优化

图片懒加载

压缩js、css

服务器开启gzip

浏览器缓存

...

发布

完成项目后将发布到自己的服务器上,首先确保服务器已安装nodejs,具体安装步骤不再赘述。

后端发布

后端采用pm2做项目管理

安装pm2

npm install pm2 -g

启动项目

cd bilibili-api && npm install

pm2 start index.js

前端发布

webpack打包

npm run build

需要注意的是,直接运行此命令可能会导致资源无法找到的问题。所以需要对webpack配置做一定的修改。

在webpack.base.conf.js文件中修改publicPath如下

output: {

path: config.build.assetsRoot,

publicPath: './', //资源的公共路径

// publicPath: process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath,

filename: '[name].js'

}

这样打包后还会出现stylus中background-image资源无法找到的问题,我采用的方式修改ExtractTextPlugin配置,在webpack.prod.conf.js中修改

new ExtractTextPlugin('[name].[contenthash].css')

将分离的css打包路径分离到static文件夹之外。

打包完成后上传到服务器/var/www/html/bilibili目录下。

配置nginx服务器。

location /bilibili {

root /var/www/html;

index index.html;

}

总结

目前主要功能都已经完成的差不多。主要还差一个预览视频与弹幕的功能尚未完成,希望能把B站首页写完,并且会持续更新中,后面可能会加上直播等功能。

相关截图:

首页:

1b396bd106a94cbce936cb5c748f642c.png

轮播:

7ec67045154436eb0f9a0b58954e8c08.png

直播:

5d14af3a8d716400b6d1c2e006f824a0.png

397cbcf624dd6debe849df515fe46187.png

排行:

6e905be1a721687204dbd9df0a27ef92.png

游戏:

d9e2d53e3e5536c5c04b6d62492b7fe1.png

拖拽排序与滚动效果:

4b990f49b484f0530f1d82e8f52dd91c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值