基于koa2、vue2、mongodb的个人网站(前端序篇)

项目地址

前言

这不阿里云搞活动可领取六个月免费使用云主机么。闲来无事就领了个,想着写个个人主页玩玩。至于采用什么技术呢?好吧,那当然是什么新用什么啦!纯粹是检验自己学习能力O(∩_∩)O哈哈~。
项目是由vue脚手架生成,项目结构 参考了手摸手,带你用vue撸后台。还有参考了部分组件封装方法。

目录结构

├── build                      // 构建相关  
├── config                     // 配置相关
├── src                        // 源代码
│   ├── api                    // 请求
│   ├── assets                 // 字体图标等静态资源
│   ├── components             // 全局公用组件
│   ├── filtres                // 全局filter
│   ├── i18n                   // 国际化语言包
│   ├── mock                   // mock数据
│   ├── router                 // 路由
│   ├── store                  // vuex
│   ├── styles                 // 样式
│   ├── utils                  // 公用方法
│   ├── view                   // 页面视图
│   ├── App.vue                // 入口页面
│   └── main.js                // 入口加载组件 初始化等
├── static                     // 第三方不打包资源
├── .babelrc                   // babel-loader 配置
├── eslintrc.js                // eslint 配置项
├── .gitignore                 // git 忽略项
├── favicon.ico                // favicon图标
├── index.html                 // html模板
└── package.json               // package.json

首先说下基本工具

构建工具

那自然是webpack啦。使用的也是vue脚手架生成的那一套。不过加了注释,算是很详尽了吧。
注意的是因为本文使用的是iview,webpack配置有个小bug,生产环境打包,字体文件引用有问题

module: {
        rules: utils.styleLoaders({
            sourceMap: config.build.productionSourceMap,
            extract: false//这里得改成false
        })
    },

还有个就是热更新问题。旧vue脚手架生成的版本会发现每次都是强制刷新。注释掉即可

// force page reload when html-webpack-plugin template changes
//声明hotMiddleware无刷新更新的时机:html-webpack-plugin 的template更改之后
// currently disabled until this is resolved:
// https://github.com/jantimon/html-webpack-plugin/issues/680
// compiler.plugin('compilation', function (compilation) {
//     compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
//         hotMiddleware.publish({ action: 'reload' })
//         cb()
//     })
// })

eslint

无论是基于什么原因,代码风格一致是必须的。何况博主处女座。自行配下即可。鉴于规则较多,费了点时间基本涵盖了所有规则,当然都是贴于我自己喜欢的。不过基本上都注释了,有兴趣的话可以看看。eslintrc.js
本人使用的IDE为vscode ,以下为本人配置


其实可以看看一些优秀团队的配置(node_modules下定位到具体包查看即可)。

实现的一些手段

首先说下咱们做什么。怎么说呢?大体就是使用vue2实现一个个人博客。这个肯定是得先有个效果图。灵感啊灵感,很难啊。这里推荐个让你文思泉涌的网站。Dribbble
我就很无耻的采用了其中一种设计。效果如下

image.png
image.png

布局

恩,使用的是响应式弹性布局。感慨下Flex真好用。以前的盒模型好难用啊。不会的小伙伴可以买本书看看响应式web设计(第二版)
这里说下断点(@media后面的min/max-width)怎么找。把屏幕拉到支持的最小宽度。然后慢慢拉开。发现看不下去了,那就是断点。超级好用吧。

axios

这个呢是有封装的。不过这里不讲怎么封装。官网很清楚有木有啊。
这里讲的是怎么处理异常。本人做法是添加一个响应拦截器,然后在拦截器里处理例如401(跳到401界面)、403(跳到403界面)常见的状态码。你要是想比如我获取文章失败,怎么catch。这个肯定是不能全局的。乖乖哪里调用哪里catch吧。

国际化

国际化采用的是vue-i18n


文件结构

想加什么语言自己新建文件就成。采用json对象分模块编写语言包。

// zh.js
const lang = {
    validator: {
        username: '请输入正确的用户名'
    },
    login: {
        login: '登录',
        logout: '退出',
        username: '用户名',
        password: '密码'
    },
    dashboard: {
        dashboardTitle: '首页'
    }
};

export default lang;

配置文件

import Vue from 'vue';
import VueI18n from 'vue-i18n';
import zhLang from './zh';
import enLang from './en';
import zhLocale from 'iview/dist/locale/zh-CN';
import enLocale from 'iview/dist/locale/en-US';
Vue.use(VueI18n);

// 自动设置语言
const navLang = navigator.language;
const localLang = navLang === 'zh-CN' || navLang === 'en-US' ? navLang : false;
const lang = window.localStorage.getItem('language') || localLang || 'zh-CN';

Vue.config.lang = lang;

// 多语言配置
const mergeZH = Object.assign(zhLocale, zhLang);
const mergeEN = Object.assign(enLocale, enLang);
Vue.locale('zh-CN', mergeZH);
Vue.locale('en-US', mergeEN);

是不是觉得很简单呢。

mock

仿真,这个可是前后端分离必备啊。这样子就无需等后端同学了。大前端就是这么傲娇
搭建可参考

await/async

嗯,很新的东西。没接触过的小伙伴可以看下阮一峰老师的ECMAScript 6 入门。比promise更加优雅有木有。

动画

有看我主页的,可以看见滚动滚轮是有动画效果的。这个实现还是废了点周折。首先是vue也才使用,其次以前写动画除了css3还有jquery。不习惯啊啊,没了jquery。这里占个坑,有空分享下我遇到的问题。

优化

推荐一个个人觉得使用方便的网站webpagetest
可以看见评分标准好几种。自行优化即可。方法网上多得很,在此不再赘述。
cdn这个老实说我还没有搞定呢,不过打算采用又拍云或者七牛。什么时候有空折腾下。

后记

感觉大致就这么些,好多别人有讲而且我也很顺利就觉得没什么可说的。
本文只是大致介绍了下个人网站用的一些实现方法。具体的情况后续有时间继续分享。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容