V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lybenson
V2EX  ›  程序员

前端 vue+后端 koa,全栈式开发 bilibili 首页

  •  7
     
  •   lybenson · 2017-04-25 15:29:25 +08:00 · 15542 次点击
    这是一个创建于 2770 天前的主题,其中的信息可能已经有所发展或是发生改变。

    预览地址: http://www.lybenson.com/bilibili/

    前言

    为什么是写哔哩哔哩(俗称 B 站)呢?其一是因为本人是 B 站的重度使用者,每周基本上都会在 B 站上看看火影忍者、暴走大事件等。另外一个原因呢,就是 B 站首页很美观大方,而且处处充满了细节。所以对于实践确实是一个不错的项目。目前的技术栈主要的采用的是前端 Vue2+后端 Koa2 的前后端分离的方式,语法全部使用 ES6/7 。关于数据也来自真实的数据接口。

    技术栈

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

    后端: koa2

    项目运行

    源码地址: https://github.com/lybenson/bilibili-vue

    如何运行

    运行前请先安装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。每次发起网络需要经历下面的步骤

    1. 请求中

      rootState.requesting = true  //请求状态更新为 true,表示请求中
      commit(TYPE.XX_REQUEST)  // 发送同步操作,请求中的数据处理
      
    2. 请求成功

      rootState.requesting = false  //请求状态更新为 false,表示请求结束
      commit(TYPE.XX_SUCCESS, response) //发送同步操作,处理请求成功后数据
      
    3. 请求失败

      rootState.requesting = false  //请求状态更新为 false,表示请求结束
      commit(TYPE.XX_SUCCESS, response) //发送同步操作,处理请求失败
      

    动画

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

    1. hover效果触发。

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

    3. 通过vue提供的动画方式。

      <transition name="fade">
       <div v-if="isSort">
           <div class="tip"></div>
           <div class="custom-bg"></div>
       </div>
      </transition>
      

    样式

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

    npm install stylus-loader --save-dev
    npm install stylus --save-dev
    

    性能优化

    • 图片懒加载

    • 压缩jscss

    • 服务器开启gzip

    • 浏览器缓存

    • ...

    发布

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

    后端发布

    后端采用pm2做项目管理

    安装pm2

    npm install pm2 -g
    

    启动项目

    cd bilibili-api && npm install 
    pm2 start index.js
    

    前端发布

    1. 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'
    }
    

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

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

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

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

    1. 配置 nginx 服务器。

      location /bilibili {
        root /var/www/html;
        index index.html;
      }
      

    总结

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

    相关截图:

    首页:

    20170423210104.png

    轮播:

    20170423213449.png

    直播:

    20170423210140.png 20170423210218.png

    排行:

    20170423210248.png

    游戏:

    20170423213519.png

    拖拽排序与滚动效果:

    20170423213599.png

    53 条回复    2017-04-27 10:28:01 +08:00
    gouchaoer
        1
    gouchaoer  
       2017-04-25 15:41:02 +08:00
    有点意思,你这个 css 和 html 模版是从 B 站复制的么,里面的 js 是复制的 B 站的还是自己重新写了一遍?
    zakokun
        2
    zakokun  
       2017-04-25 15:42:20 +08:00
    你考虑过 B 站服务器的感受麽?
    Rubicker666
        3
    Rubicker666  
       2017-04-25 15:42:57 +08:00 via Android
    666
    LeeSeoung
        4
    LeeSeoung  
       2017-04-25 15:44:14 +08:00
    star
    jiar
        5
    jiar  
       2017-04-25 15:49:41 +08:00
    mark
    lybenson
        6
    lybenson  
    OP
       2017-04-25 16:46:08 +08:00
    @zakokun 你太小看 B 站服务器了
    Tunar
        7
    Tunar  
       2017-04-25 16:56:52 +08:00 via Android
    掘金那里已喜欢😘
    zoobop
        8
    zoobop  
       2017-04-25 16:57:07 +08:00
    厉害了~~~支持。 star
    xbdsky
        9
    xbdsky  
       2017-04-25 16:59:53 +08:00
    厉害了~~~支持+1 star
    smithtel
        10
    smithtel  
       2017-04-25 17:07:29 +08:00
    小水管炸了
    kely
        11
    kely  
       2017-04-25 17:12:47 +08:00
    厉害了!!我的哥!想问一下,写了多久?
    learnshare
        12
    learnshare  
       2017-04-25 17:23:02 +08:00
    B 站首页很美观大方 不太认同,不够美
    xrlin
        13
    xrlin  
       2017-04-25 17:31:25 +08:00 via iPhone
    @learnshare b 站首页感觉太杂了
    yuluofanchen
        14
    yuluofanchen  
       2017-04-25 17:43:55 +08:00
    网站打开速度太慢了。。。。。。








































































    ps :不认为 B 站的首页很好看咧。不过萝卜白菜,各有所爱。
    airycanon
        15
    airycanon  
       2017-04-25 17:44:46 +08:00
    请问楼主,项目目录结构是用什么画出来的?
    charexcalibur
        16
    charexcalibur  
       2017-04-25 17:44:58 +08:00
    厉害啦 233333 我愿意给你一枚硬币
    Jialin
        17
    Jialin  
       2017-04-25 18:01:11 +08:00
    那么 SEO 呢?
    BlackCat02
        18
    BlackCat02  
       2017-04-25 18:05:24 +08:00
    收下我的硬币
    beyoung
        19
    beyoung  
       2017-04-25 18:08:29 +08:00
    @yuluofanchen http://bt0.com/ 这个站的首页怎么样 评价一下
    ecmadao
        20
    ecmadao  
       2017-04-25 18:10:03 +08:00 via iPhone
    😂可以考虑什么时候去 B 站直播一下写 B 站
    binux
        21
    binux  
       2017-04-25 18:14:08 +08:00
    我还以为是招聘贴呢
    AlphaTr
        22
    AlphaTr  
       2017-04-25 18:35:16 +08:00   ❤️ 1
    @airycanon 有个 tree 的命令,再加上 level 的限定,复制出来就行
    lybenson
        23
    lybenson  
    OP
       2017-04-25 18:40:33 +08:00
    @Tunar 亲亲
    lybenson
        24
    lybenson  
    OP
       2017-04-25 18:42:19 +08:00   ❤️ 1
    @airycanon windows 下不太清楚, mac 下使用 homebrew 安装 tree
    zyEros
        25
    zyEros  
       2017-04-25 18:59:30 +08:00 via iPhone
    滚动性能太差, iphone6 的 safari 滚动直接出白屏
    Nitromethane
        26
    Nitromethane  
       2017-04-25 19:31:40 +08:00
    讲真难度确实不大~
    adubi
        27
    adubi  
       2017-04-25 20:16:37 +08:00
    楼主,好像我们在一个地方的
    boyhailong
        28
    boyhailong  
       2017-04-25 20:41:04 +08:00
    厉害了 已 star
    sobigfish
        29
    sobigfish  
       2017-04-25 20:53:07 +08:00
    我还以为是 app 页面呢,结果是 pc 的=。=
    FEDT
        30
    FEDT  
       2017-04-25 22:16:43 +08:00 via Android
    关注一下
    sox
        31
    sox  
       2017-04-25 23:30:17 +08:00 via iPhone
    啥叫全栈式开发?
    DukeAnn
        32
    DukeAnn  
       2017-04-26 08:44:39 +08:00
    厉害了
    kfll
        33
    kfll  
       2017-04-26 09:34:33 +08:00 via Android   ❤️ 5
    @sox 就是作者是全程站立着开发的,近几年比较流行
    Ixizi
        34
    Ixizi  
       2017-04-26 09:35:37 +08:00
    很强。
    pyufftj
        35
    pyufftj  
       2017-04-26 09:51:21 +08:00
    @kfll 我就服你
    ibufu
        36
    ibufu  
       2017-04-26 10:41:22 +08:00
    为啥子国内这么热衷于 copy 呢
    fhefh
        37
    fhefh  
       2017-04-26 11:42:22 +08:00
    @airycanon #15 如果用的是 Mac brew install tree 然后 tree 你的目录
    fhefh
        38
    fhefh  
       2017-04-26 11:43:25 +08:00
    @beyoung #19 http://bt0.com/ 这页面不错耶
    beyoung
        39
    beyoung  
       2017-04-26 11:57:54 +08:00 via iPhone
    @fhefh 这个站也我喜欢的风格 不过细节有太多要完善的了
    anthozoan77
        40
    anthozoan77  
       2017-04-26 14:26:29 +08:00
    很棒啊!
    BoiledEgg
        41
    BoiledEgg  
       2017-04-26 14:32:56 +08:00
    然而我看并没有开启 gzip 啊
    qfdk
        42
    qfdk  
       2017-04-26 14:59:24 +08:00 via iPhone
    @lybenson 然而经常 502
    beyoung
        43
    beyoung  
       2017-04-26 15:12:24 +08:00
    @kfll 全站好处蛮多的 尤其对身体健康
    lybenson
        44
    lybenson  
    OP
       2017-04-26 17:53:07 +08:00
    @adubi 给老乡递 py
    lybenson
        45
    lybenson  
    OP
       2017-04-26 17:53:49 +08:00
    @BoiledEgg 已经开启 gzip 了
    lybenson
        46
    lybenson  
    OP
       2017-04-26 17:54:45 +08:00
    @qfdk 国外服务器,多担待
    qfdk
        47
    qfdk  
       2017-04-26 18:05:58 +08:00 via iPhone
    @lybenson 还以为你把 b 站的服务器也搞了 哈哈哈 跳转还是到 b 站
    Geoion
        48
    Geoion  
       2017-04-26 22:27:09 +08:00
    厉害了
    Geoion
        49
    Geoion  
       2017-04-26 22:31:33 +08:00
    悬停预览封面好像没实现
    adubi
        50
    adubi  
       2017-04-26 22:56:37 +08:00
    @lybenson 联系方式来一发
    Anybfans
        51
    Anybfans  
       2017-04-27 09:02:50 +08:00
    chrome 好像滚动不到最后一个标签
    lybenson
        52
    lybenson  
    OP
       2017-04-27 10:27:16 +08:00
    @Anybfans 正常哦
    lybenson
        53
    lybenson  
    OP
       2017-04-27 10:28:01 +08:00
    @adubi q: 757766483 欢迎联系哈
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2768 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 08:13 · PVG 16:13 · LAX 00:13 · JFK 03:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.