趁着周末偷来一点闲,总结近期的工作和学习,想着该花点心思把N3-admin这套基于N3-components的单页应用模板简单的给介绍一下。

首发于个人博客;blog.lxstart.net
项目路径: https://github.com/N3-compone...
ps: 本项目不同于vue-admin等模板项目介绍大量的组件,基础组件的用法请参考:https://n3-components.github....

<!-- more -->

1、概述

首先N3-admin是一个基于vue / vuex / vue-router / N3 / axios 的单页应用,适用于单页应用的快速上手,并不仅限于N3-components的使用,而是提供一个比较完善的项目构建的思路和结构,提供给初学者学习。同时也是一套可扩展的Vue单页应用开发模板。

项目工程基于Vue-cli,因此大部分同学都能快速上手和理解,往下介绍一下特性和结构。

2、特性

  • [x] 项目工程相关

    • [x] 开发环境;静态文件服务器、HTTP代理、热更新

    • [x] 生产构建:代码编译提取压缩合并混淆hash命名base64~

    • [x] eslint

    • [x] babel

    • [x] webpack 2.x

  • [x] vue

    • [x] 组件分级 [路由级组件、复用型组件、基础组件(N3)]

    • [x] Vue扩展 [filters、directives等]

  • vue-router

    • [x] 二级路由

    • [x] 转场动画

    • [x] 路由拦截器

  • vuex

    • [x] 多模块(module)支持

  • [x] axios

    • [x] 支持多实例

    • [x] 请求、响应拦截器

    • [x] Vue 扩展,通过实例的方法可访问

  • [x] layout 布局

  • [x] 全局进度条 Nprogress

  • [x] css 预处理

    • [x] less

    • [x] postcss

    • [] stylus <= 仅需安装预处理器和loader

    • [] sass / scss <= 仅需安装预处理器和loader

  • [x] API 调用支持

    • [x] 接口配置

    • [] mock

3、布局方式

二级路由下生效

4、文件结构

.
├── README.md <= 项目介绍
├── build <= 工程构建相关 <Vue-cli>
│   ├── build.js <= 构建脚本
│   ├── check-versions.js <= Node Npm版本检查
│   ├── dev-client.js <= 开发客户端:浏览器刷新
│   ├── dev-server.js <= 开发服务器:静态文件服务器、代理、热更新
│   ├── utils.js <= utils
│   ├── webpack.base.conf.js <= webpack基础配置
│   ├── webpack.dev.conf.js <= webpack开发配置
│   └── webpack.prod.conf.js <= webpack生产配置
├── config <= 工程构建配置:开发服务器端口、代理,静态资源打包位置等
│   ├── dev.env.js <= 开发环境配置
│   ├── index.js <= 入口
│   ├── prod.env.js <= 生产环境配置
│   └── test.env.js <= 测试环境配置
├── index.html <= 单页应用入口
├── package-lock.json <= Npm Package 版本锁
├── package.json <= Npm Package 配置
├── src <= 项目源代码
│   ├── App.vue <= Vue 根组件
│   ├── api.js <= api 配置
│   ├── assets <= 静态资源
│   │   ├── font
│   │   │   ├── iconfont.eot
│   │   │   ├── iconfont.svg
│   │   │   ├── iconfont.ttf
│   │   │   └── iconfont.woff
│   │   ├── images
│   │   │   └── logo.png
│   │   ├── logo.png
│   │   └── styles
│   │   └── base.css
│   ├── config.js <= 项目配置
│   ├── extend <= Vue 扩展相关
│   │   ├── filters.js <= 全局过滤器
│   │   ├── directive.js <= 全局指令
│   │   └── index.js <= 扩展入口
│   ├── layout <= 布局组件
│   │   ├── container.vue
│   │   ├── header.vue
│   │   ├── index.vue
│   │   ├── levelbar.vue
│   │   └── navbar.vue
│   ├── main.js <= Vue 入口
│   ├── mock <= Mock
│   ├── router <= 路由配置
│   │   ├── index.js
│   │   └── routes.js
│   ├── store <= Vuex
│   │   ├── actions
│   │   │   └── user.js
│   │   ├── index.js
│   │   ├── modules
│   │   │   ├── app.js
│   │   │   └── user.js
│   │   └── mutation-types.js
│   ├── style <= 样式文件
│   │   └── define.less
│   ├── utils <= utils
│   │   ├── axios.js <= axios
│   │   ├── const.js <= 常量
│   │   ├── index.js
│   │   └── storage.js <= storage
│   └── widgets <= 可复用组件
│   └── views <= 路由级别的组件
│   ├── Login.vue
│   ├── form
│   │   └── index.vue
│   ├── table
│   │   └── index.vue
│   └── test
│   └── query.vue
├── static <= 服务器静态资源
│   └── favicon.ico
└── test <= 测试文件夹
└── unit
├── index.js
├── karma.conf.js
└── specs
└── Hello.spec.js

5、使用说明

  • 开发环境

npm run dev
  • 生产环境

npm run build

6、效果图

  • 总览

  • 登录

  • Table

  • Form

一套Vue的单页模板:N3-admin的更多相关文章

  1. 做一个gulp+webpack+vue的单页应用开发架子

    1.目标 最近项目上的事情不多,根据我自己的开发习惯,决定开发一些简单的开发架子,方便以后事情多的时候直接套用.本文讲的一个gulp+webpack+vue的单页应用架子,想要达到的目的: 可以通过命 ...

  2. [vue]spa单页开发及vue-router基础

    - 了解spa页面跳转方式:(2种) spa: 单页跳转方式 开发(hash模式): https://www.baidu.com/#2313213 生产(h5利于seo): history.pushS ...

  3. 使用Vue构建单页应用一

    一. 环境准备 1 安装Node.js  最好安装node.js-6.X.X 以上版本,https://nodejs.org/en/    我使用的是  v6.3.1 Current 版本.Node. ...

  4. Vue 部署单页应用,刷新页面 404/502 报错

    在 Vue 项目中,可以选择 hash或者 history.pushState() 实现路由跳转.如果在路由中使用history模式: export default new Router({ mode ...

  5. vue实现单页应用demo

    vue + webpack +ES6/7 + axiso + vuex + vue-router构建项目前端,node + express + mongodb 开发后台 项目demo地址 https: ...

  6. vue 修改单页标题 --- document.title

    方法1. 在需要的组件或者页面内设置 document.title = response.data.res.title 方法2. <head> <meta http-equiv=&q ...

  7. vue项目单页

    <template> <div> <div v-if="type === 'A'">A</div> <div v-else-i ...

  8. vue单页应用前进刷新后退不刷新方案探讨

    引言 前端webapp应用为了追求类似于native模式的细致体验,总是在不断的在向native的体验靠拢:比如本文即将要说到的功能,native由于是多页应用,新页面可以启用一个的新的webview ...

  9. Laravel 5.5 + Vue 开发单页应用

    上次我用 laravel5.3 + Vue 开发了一个简单的单页应用,这次我打算将其升级到 laravel5.5,在升级的过程中,做一下记录,其源码放在 github 上面,源码地址   开发环境 软 ...

随机推荐

  1. 基于Lumisoft.NET组件,使用IMAP协议收取邮件

    在早期一直使用Lumisoft.NET组件来进行邮件的处理查找,对于邮件的处理非常方便,之前在随笔<基于Lumisoft.NET组件的POP3邮件接收和删除操作>中也介绍过基于POP3和S ...

  2. 矩池云 | Tony老师解读Kaggle Twitter情感分析案例

    今天Tony老师给大家带来的案例是Kaggle上的Twitter的情感分析竞赛.在这个案例中,将使用预训练的模型BERT来完成对整个竞赛的数据分析. 导入需要的库 import numpy as np ...

  3. 矩池云 | 搭建浅层神经网络"Hello world"

    作为图像识别与机器视觉界的 "hello world!" ,MNIST ("Modified National Institute of Standards and Te ...

  4. 4. 堪比JMeter的.Net压测工具 - Crank 进阶篇 - 认识wrk、wrk2

    目录 堪比JMeter的.Net压测工具 - Crank 入门篇 堪比JMeter的.Net压测工具 - Crank 进阶篇 - 认识yml 堪比JMeter的.Net压测工具 - Crank 进阶篇 ...

  5. Linux备份数据库,mysqldump命令实例详解

    mysqldump是mysql数据库中备份工具,用于将MYSQL服务器中的数据库以标准的sql语言的方式导出,并保存到文件中. 语法: mysqldump (选项) 选项: --add-drop-ta ...

  6. Cocoapods插件机制浅析

    原文链接 背景 虽然做iOS开发的过程中使用过 Cocoapods, 但是对里面的细节了解其实不算太多,直到这两年做织女项目时,通过对Cocoapods进行Qt支持改造才开始深入了解部分细节,这个过程 ...

  7. 1. 企业级调度器LVS初识、工作模式详解

    想学习更多相关知识请看博主的个人博客 1. LVS官网 LVS 时全球最流程的四层负载均衡开源软件. LVS 官网:http://www.linuxvirtualserver.org/ 2.Linux ...

  8. pandas常用操作详解——.loc与.iloc函数的使用及区别

    loc与iloc功能介绍:数据切片.通过索引来提取数据集中相应的行数据or列数据(可以是多行or多列) 总结: 不同:1. loc函数通过调用index名称的具体值来取数据2. iloc函数通过行序号 ...

  9. Linux卸载源码编译安装的软件

    使用auto-apt 和 checkinstall,具体命令如下 #安装auto-apt和checkinstall apt install auto-apt checkinstall #在源码目录中 ...

  10. hadoop-SSH免密登录配置

    一:配置基础环境 一.修改主机名 修改 master 机器主机名 [root@server ~]# hostnamectl set-hostname master-wzg [root@server ~ ...