vue-cli 搭建博客


1. 环境搭建
npm install -g vue-cli //全局安装 vue-cli
vue init webpack my-blog //创建基于webpack的博客
cd my-blog //进入创建的文件夹中
npm install //安装依赖模块
npm run dev //打开localhost:8080看看环境是否搭建成功

创建成功后首页如下图


此时项目的结构如下:build 与 config 是与 webpack 配置相关的文件,node_modules 是相关依赖文件,src 是源文件,App 是创建的 vue 对象,项目的总的模板,main.js 与 index.html 是入口文件


2. 创建组件

在 src 中创建组件文件夹,每个组件由 template、style 及 script 文件构成,style 中加入 scoped 关键字可以确保该样式只作用于本组件


3. 配置路由

router 文件夹中有 index.js 文件,里面给出了路由配置的范例:创建 vue-router 对象,参数是一个对象,对象有一个属性 routes,值为数组,数组的成员是包含 path 属性和 component 属性的对象,图中 @ 是在配置中定义的,指向 src 文件夹,可以在 src 中创建各个组件,然后 import 导入该文件中



还可以设置模块的懒加载,只有当用户进入某模块时才去引入该模块



在进入每个页面前先判断该页面是否有权限(store 在引入
vuex 后创建)
router.beforeEach((to, from, next) => {
  if (to.matched.some(record => record.meta.requiresAuth)) {
    // this route requires auth, check if logged in
    // if not, redirect to login page.
    store.dispatch('checkLogin').then(isLogin=>{
      if(!isLogin){
        next({
          path:'/login',
          query: { redirect: to.fullPath }
        })
      }else {
        next()
      }
    })
  } else {
    next() // 确保一定要调用 next()
  }
})

export default router

最后在 main.js 引入该文件

4. 封装数据请求接口及后端提供的各API接口

接口封装好后,可以使后续使用更加方便、结构更清晰,在项目中用到了axios,axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,本质上也是对原生XHR的封装,只不过它是Promise的实现版本,它具有防御 XSRF 攻击的作用。先安装 axios 组件,然后通过 import 导入文件中

5. 创建公共样式(assets)及公共组件(components)
6. 创建状态管理文件夹 store

文件夹结构如下,在 modules 下的每个模块文件中定义 state、mutations、getters、actions 对象,其中 getters 下的属性,通过 vuex 的部署可在全局状态下被 vue 子组件获取



安装 vuex 管理 vue 中的状态,下图为 index.js 文件

import Vue from 'vue'
import Vuex from 'vuex'
import auth from './modules/auth'
import blog from './modules/blog'

Vue.use(Vuex)
export default new Vuex.Store({
    modules:{
        auth,
        blog
    }
})

最后在 main.js 中引入该文件,以供全局使用,当其他组件想要使用 store 中的状态时可以从 vuex 中引入局部方法,如mapGetters、mapMutations 及 mapActions,mapGetters 引入的状态不必在组件的 data 属性中再定义,mapMutations 引入的方法,需在组件的 methods 中另行定义方法,在方法中作为回调使用

7. 进一步完善页面
8. 打包文件
npm run build

生成 dist 文件夹,可以通过创建 git 库的方式,发布到 github 上

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

推荐阅读更多精彩内容

  • ## 框架和库的区别?> 框架(framework):一套完整的软件设计架构和**解决方案**。> > 库(lib...
    Rui_bdad阅读 2,907评论 1 4
  • vue-cli搭建项目 确保安装了node与npm 再目标文件夹下打开终端 执行cnpm i vue-cli -g...
    Akiko_秋子阅读 3,232评论 1 22
  • vue去哪网跟学笔记 记录学习点滴 1. 初始化项目 1.1 手机显示配适 minimum-scale=1.0,m...
    noobakong阅读 2,244评论 0 16
  • vue-cli3项目搭建配置以及性能优化 在之前的开发中主要用的是vue-cli2,最近空闲时间比较多,接下来有新...
    bayi_lzp阅读 19,483评论 16 68
  • 一、 组件component 1. 什么是组件? 组件(Component)是 Vue.js 最强大的功能之一。组...
    饥人谷_Leonardo阅读 1,966评论 0 18