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 上

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

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

友情链接更多精彩内容