vue-cli入门之项目结构分析


Posted in Javascript onApril 20, 2017

前言

在上一篇项目搭建文章中,我们已经下载安装了node环境以及vue-cli,并且已经成功构建了一个vue-cli项目,那么接下来,我们来梳理一下vue-cli项目的结构。

总体框架

一个vue-cli的项目结构如下,其中src文件夹是需要掌握的,所以本文也重点讲解其中的文件,至于其他相关文件,了解一下即可。

vue-cli入门之项目结构分析

文件结构细分

1.build——[webpack配置]

build文件主要是webpack的配置,主要启动文件是dev-server.js,当我们输入npm run dev首先启动的就是dev-server.js,它会去检查node及npm版本,加载配置文件,启动服务。

vue-cli入门之项目结构分析

2.config——[vue项目配置]

config文件主要是项目相关配置,我们常用的就是当端口冲突时配置监听端口,打包输出路径及命名等

vue-cli入门之项目结构分析

3.node_modules——[依赖包]

node_modules里面是项目依赖包,其中包括很多基础依赖,自己也可以根据需要安装其他依赖。安装方法为打开cmd,进入项目目录,输入npm install [依赖包名称],回车。

在两种情况下我们会自己去安装依赖:

(1)项目运行缺少该依赖包:例如项目加载外部css会用到的css-loader,路由跳转vue-loader等(安装方法示例:npm install css-loader)

(2)安装插件:如vux(基于WEUI的移动端组件库),vue-swiper(轮播插件)

注:有时会安装指定依赖版本,需在依赖包名称后加上版本号信息,如安装11.1.4版本的vue-loader,输入npm install vue-loader@11.1.4

4.src——[项目核心文件]

项目核心文件前面已经进行了简单的说明,接下来重点讲解main.js,App.vue,及router的index.js

4.1 index.html——[主页]

index.html如其他html一样,但一般只定义一个空的根节点,在main.js里面定义的实例将挂载在根节点下,内容都通过vue组件来填充

vue-cli入门之项目结构分析
index.html

4.2 App.vue——[根组件]

一个vue页面通常由三部分组成:模板(template)、js(script)、样式(style)

vue-cli入门之项目结构分析
App.vue

【template】

其中模板只能包含一个父节点,也就是说顶层的div只能有一个(例如下图,父节点为#app的div,其没有兄弟节点)

<router-view></router-view>是子路由视图,后面的路由页面都显示在此处

打一个比喻吧,<router-view>类似于一个插槽,跳转某个路由时,该路由下的页面就插在这个插槽中渲染显示

【script】

vue通常用es6来写,用export default导出,其下面可以包含数据data,生命周期(mounted等),方法(methods)等,具体语法请看vue.js文档,在后面我也会通过例子来说明。

【style】

样式通过style标签<style></style>包裹,默认是影响全局的,如需定义作用域只在该组件下起作用,需在标签上加scoped,<style scoped></style>

如要引入外部css文件,首先需给项目安装css-loader依赖包,打开cmd,进入项目目录,输入npm install css-loader,回车。安装完成后,就可以在style标签下import所需的css文件,例如:

<style>

  import './assets/css/public.css'

</style>

这样,我们就可以把style下的样式封装起来,写到css文件夹,再引入到页面使用,整个vue页面也看上去更简洁。

4.3 main.js——[入口文件]

main.js主要是引入vue框架,根组件及路由设置,并且定义vue实例,下图中的

components:{App}就是引入的根组件App.vue

后期还可以引入插件,当然首先得安装插件。

vue-cli入门之项目结构分析
main.js

4.4 router——[路由配置]

router文件夹下,有一个index.js,即为路由配置文件

vue-cli入门之项目结构分析
router下的index.js

这里定义了路径为'/'的路由,该路由对应的页面是Hello组件,所以当我们在浏览器url访问http://localhost:8080/#/时就渲染的Hello组件

类似的,我们可以设置多个路由,‘/index','/list'之类的,当然首先得引入该组件,再为该组件设置路由。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个用javascript写的select支持上下键、首字母筛选以及回车取值的功能
Sep 09 Javascript
jQuery使用动态渲染表单功能完成ajax文件下载
Jan 15 Javascript
append和appendTo的区别以及appendChild用法
Dec 24 Javascript
鼠标悬停小图标显示大图标
Jan 22 Javascript
快速解决js动态改变dom元素属性后页面及时渲染的问题
Jul 06 Javascript
Listloading.js移动端上拉下拉刷新组件
Aug 04 Javascript
js模糊查询实例分享
Dec 26 Javascript
jQuery操作json常用方法示例
Jan 04 Javascript
jQuery排序插件tableSorter使用方法
Feb 10 Javascript
Angularjs为ng-click事件传递参数
Jun 15 Javascript
javaScript产生随机数的用法小结
Apr 21 Javascript
HTML+JavaScript实现扫雷小游戏
Sep 30 Javascript
JS+HTML5实现上传图片预览效果完整实例【测试可用】
Apr 20 #Javascript
详解Vue使用 vue-cli 搭建项目
Apr 20 #Javascript
解决AngualrJS页面刷新导致异常显示问题
Apr 20 #Javascript
Vue.js实现模拟微信朋友圈开发demo
Apr 20 #Javascript
AngularJS 单选框及多选框的双向动态绑定
Apr 20 #Javascript
Vue如何引入远程JS文件
Apr 20 #Javascript
AngularJS改变元素显示状态
Apr 20 #Javascript
You might like
php foreach、while性能比较
2009/10/15 PHP
PHP sprintf() 函数的应用(定义和用法)
2012/06/29 PHP
通过缓存数据库结果提高PHP性能的原理介绍
2012/09/05 PHP
php二维数组排序与默认自然排序的方法介绍
2013/04/27 PHP
php实现简易聊天室应用代码
2015/09/23 PHP
PHP实现的字符串匹配算法示例【sunday算法】
2017/12/19 PHP
jquery中获取元素的几种方式小结
2011/07/05 Javascript
js写出遮罩层登陆框和对联广告并自动跟随滚动条滚动
2014/04/29 Javascript
详谈javascript中的cookie
2015/06/03 Javascript
基于JS代码实现当鼠标悬停表格上显示这一格的全部内容
2016/06/12 Javascript
纯js实现手风琴效果代码
2020/04/17 Javascript
基于jQuery实现左侧菜单栏可折叠功能
2016/12/27 Javascript
基于Nodejs利用socket.io实现多人聊天室
2017/02/22 NodeJs
jQuery上传多张图片带进度条样式(DEMO)
2017/03/02 Javascript
nodejs个人博客开发第七步 后台登陆
2017/04/12 NodeJs
Vue.js与 ASP.NET Core 服务端渲染功能整合
2017/11/16 Javascript
mongodb初始化并使用node.js实现mongodb操作封装方法
2019/04/02 Javascript
mui js控制开关状态、修改switch开关的值方法
2019/09/03 Javascript
使用xampp将angular项目运行在web服务器的教程
2019/09/16 Javascript
pycharm的console输入实现换行的方法
2019/01/16 Python
python文档字符串(函数使用说明)使用详解
2019/07/30 Python
Pandas 解决dataframe的一列进行向下顺移问题
2019/12/27 Python
Python内置异常类型全面汇总
2020/05/28 Python
python实现按键精灵找色点击功能教程,使用pywin32和Pillow库
2020/06/04 Python
python与c语言的语法有哪些不一样的
2020/09/13 Python
天逸系统(武汉)有限公司Java笔试题
2015/12/29 面试题
室内设计实习自我鉴定
2013/09/25 职场文书
经销商培训邀请函
2014/01/21 职场文书
毕业生找工作自荐书
2014/06/30 职场文书
教师工作失职检讨书
2014/09/18 职场文书
新婚姻法离婚协议书范文
2014/11/30 职场文书
入党现实表现材料
2014/12/23 职场文书
25句企业管理语录:助你迅速打开思路,句句经典!
2020/01/14 职场文书
Python还能这么玩之用Python做个小游戏的外挂
2021/06/04 Python
JavaScript高级程序设计之变量与作用域
2021/11/17 Javascript
如何设置多台电脑共享打印机?多台电脑共享打印机的方法
2022/04/08 数码科技