构建Vue项目

按照官网教程安装

//先安装脚手架
cnpm i -g vue-cli //查看项目目标列表: webpack browserify pwa 等项目模板
vue list //使用webpack模板创建项目
vue init webpack my-project //进去新创建的文件夹
cd my-project //打开package.json 看scripts字段
//dev 可以使用npm run dev 或者 npm start 开启开发模式
//build 可以使用npm run build 打包项目,生成最终
//还有其他的命令根据创建项目的时候的选择决定

webpack模板默认安装了vuevue-routerpostcssbabel,如果需要其它的可以自己再安装。

安装sass

cnpm i --save-dev node-sass sass-loader

安装好后就可以在.vue文件style便签设置 <style scoped lang="scss">就可以开启scss功能

安装axios

cnpm i --save axios

main.js文件中引入axios并将其指定为Vue.prototype.$http = axios

//main.js
//全局的Vue,所有组件都是这个Vue的实例
import Vue form 'vue';
import axios from 'axios'; //由于所有Vue的组件都继承于这个全局的Vue,所有的组件都能够通过$http拿到axios
//自定义全局属性要带'$'
Vue.prototype.$http = axios;

安装vuex

cnpm i --save vuex

main.js文件中引入Vuex,使用Vue.use(Vuex)且创建store,然后将store添加到全局 new Vue({store})

import Vue from 'vue'
import Vuex from 'vuex'
import App from './App' Vue.use(Vuex) const store = new Vuex.Store({
state: {
count: 0
}
}) new Vue({
el: '#app',
component: App,
store,
template: "</App>"
})

项目结构

  • /src

    • /assets
    • /components
    • /containers
    • /modules
    • /router
    • /scss
    • App.vue
    • main.js

/assets

主要放图片字体等静态文件

/components

公用组件,所有页面都可以公用的组件,或者单例组件,像弹出窗按钮、等可以多次复用的组件

/containers

页面组件router中的路由组件,相对路由来划分这个文件夹的结构

比如路由/user/change_psw/login

  • /containers

    • User.vue
    • /user
      • ChangePsw.vue
    • Login.vue
import User from '@/containers/User';
import ChangePsw from '@/containers/user/ChangePsw';
import Login from '@/containers/Login'; const router = [
{
// 匹配 /user
path: '/user',
component: User,
children: [
{
// 匹配 /user/change_psw
path: 'change_psw',
component: ChangePsw
}
]
}, {
// 匹配 /login
path: '/login',
component: Login
}
]

/modules

Vuex的状态管理,这里按每个页面划分,当然还可以别的方法,这里只供参考

  • /modules

    • modules.js
    • index.js
    • user.js

modules.js负责将所有模块收集起来(类似reduce的合成),index.jsuser.js分别管理页面index和页面user的全局状态

//modules.js
import index from './index'
import user from './user' export default {
index,
user
}
//index.js
export default {
namespaced: true,
state: {
a: 1
}
}
//user.js
export default {
namespaced: true,
state: {
a: 2
}
}

除了这些模块的状态,还有一个全局的状态,如果全局的状态有点大,可以将其独立成一个文件。

若超大,再开文件夹,再细化。同理,页面状态也可以。

最后在mian.js装载这些模块

import modules from '@/modules/modules';
import Vuex from 'vuex';
import Vue from 'vue'; const store = new Vuex.Store({
modules,
// ...定义全局的状态
}) new Vue({
store,
// ... 其他的配置
})

/router

如果项目比较大,可以按模块来划分这个文件夹的结构。小项目,一个文件即可。

  • /router

    • buy-ticket.js
    • index.js

和别的文件一样,index.js是所有模块路由的总和,buy-ticket.js是买票模块的路由

由于vue的路由是可以嵌套的,我们完全可以拆分路由,然后再合并。

//buy-ticket.js

export default [
{
//路由配置
},
{
//路由配置
}
]
//index.js 借助数组扩展符 或者 成为嵌套路由children的值

import Vue from 'vue';
import Router from 'vue-router';
import buyTicketRouters from '@/router/buy-ticket';
import Index from '@/containers/Index';
import Ticket from '@/containers/Ticket'; Vue.use(Router); export default new Router({
routes: [
{
path: '/',
components: Index
},
...buyTicketRouters,
//采用children
{
path: '/ticket'
components: Ticket,
children: buyTicketRouters
}
]
})

具体项目,要按项目的功能来拆分,以上只供参考。

/scss

这个样式项目结构,一言难尽,可以了解我的scss相关的文章

Sass项目结构之 7-1模式

Vue构建项目的更多相关文章

  1. vue 构建项目vue-cli

    1.首先得有node和npm的环境,node的下载:http://nodejs.org/download/.安装node之后,npm也自动生成了,显示版本号就意味着安装成功 2.接下来就是安装vue- ...

  2. vue 构建项目遇到的请求本地json问题

    在本地测试的json没有问题,但是打包后,发现json 的路径不对了,变成了绝对路径 解决方法: 建立的json文件需要放置  根目录/static下.如项目名/static/data.json,这边 ...

  3. vue 构建项目 文件引入

    1.vue引用依赖文件.  举例:axios 先安装 axios.如果直接安装 vue-axios 会报错 npm install axios npm install --save axios vue ...

  4. vue 构建项目遇到的问题

    1.我在打包完成后,打开index.html文件发现地址并没有携带路由. config下的 index.js 中的build命令的配置有一个属性叫assetsPublicPath,它的值为‘/’.意思 ...

  5. 关于vue构建项目的一些指令

    第一步: brew install nodejs(MAC机子下)  Windows直接官网下载对应版本node.js 第二步: 获取nodejs模块安装目录访问权限(Windows系统忽略)sudo ...

  6. 【记录】vue构建项目npm install错误run `npm audit fix` to fix them, or `npm audit` for details

    今天构建vue项目执行npm install初始化后报错 run `npm audit fix` to fix them, or `npm audit` for details 出现这问题控制台会有一 ...

  7. vue构建项目全过程

    1.node版本请更新到6.9.X版本以上,不然npm依赖会出问题 2.命令行里运行npm install --global vue-cli 3.npm install --global webpac ...

  8. Webpack+Vue构建项目

    第一步:单纯的搭建出来我们的项目,并且通过webpack打包一个bundle.js然后运行起来 步骤: 1.建立项目必要的文件和文件夹(见截图) 2.配置webpack.develop.config. ...

  9. vue构建项目步骤

    1.node版本请更新到6.9.X版本以上,不然npm依赖会出问题 2.命令行里运行npm install --global vue-cli 3.npm install --global webpac ...

随机推荐

  1. 3DMAX 4角色蒙皮

    1 角色建模 略,以后补充 2 骨骼绑定 一般不用骨骼直接拉,Biped足够,以后适当补充骨骼直接拉的操作 1 将Biped骨骼和模型对齐 1 创建biped之后,第一步一要先选择,然后再对位骨骼到模 ...

  2. Mysql 主从(转)

    转自 http://blog.csdn.net/hguisu/article/details/7325124

  3. noip2017普及组

    过了这么久才来写博客,也是我这么一段时间都很低迷吧.... 老实来说,今年应该是要打提高组的...可还是打了普及组... 其实最猥琐的还是我连普及都写挂了,作为一个学了两年的人,图论,进阶dp都写过的 ...

  4. Image.resize()和Image.thumbnail()的区别

    Image.resize()和Image.thumbnail()的区别 根据代码和代码注释, 这两个函数都是对图片进行缩放, 两者的主要区别如下: resize()函数会返回一个Image对象, th ...

  5. Codeforces 1106F(数论)

    要点 998244353的原根g = 3,意味着对于任意\[1 <= x,y<p\]\[x\neq\ y\]\[g^x\%p\neq\ g^y\%p\]因此可以有构造序列\(q(a)与a一 ...

  6. [洛谷P1434] [SHOI2007]滑雪

    题目链接: here we go 题外话: 谁能想到这是一道咕了两年的\(AC\)呢--当年是在搜索还半懂不懂的时候遇到的这道题,感觉真是难得要命()所以一直拖着不做,后面就下意识地逃避了搜索相关的内 ...

  7. siege官方文档(译)(二)

    WHY DO I NEED IT? Siege was written for both web developers and web systems administrators. siege是为了 ...

  8. h5画圆

    下面一段代码是,h5的画圆,半圆,四分之一圆等效果 <!DOCTYPE html> <html lang="en"> <head> <me ...

  9. IE浏览器兼容background-size

    background-size是CSS3新增的属性,IE8以下不支持,通过滤镜实现background-size效果 background-size:contain; // 缩小图片来适应元素的尺寸( ...

  10. 在PaaS上开发Web、移动应用(2)

    在PaaS上开发Web.移动应用(2) PaaS学习笔记目录 PaaS基础学习(1) 在PaaS上开发Web.移动应用(2) PaaS优点与限制(3) 6. 巨型代码,是指持续不断地向一个应用程序添加 ...