Vue使用vue-cli创建项目


Posted in Javascript onSeptember 01, 2017

本文介绍了Vue使用vue-cli创建项目,分享给大家,具体如下:

vue-cli 是一个官方发布vueJS项目脚手架:https://github.com/vuejs/vue-cli

我创建的模板项目:https://github.com/Aleczhang1992/my-vue-project/tree/dev

Vue使用vue-cli创建项目

Vue使用vue-cli创建项目

一、步骤

1.要求已安装Node.js (>=4.x, 6.x preferred) and Git.

可以设置cnpm可以提升依赖包下载速度:

npm install -g cnpm --registry=https://registry.npm.taobao.org

安装vue-cli

sudo npm install -g vue-cli

2.创建模板项目

命令格式:vue init <template-name> <project-name>

其中template-name是可选模板项,project-name是创建项目的名称。目前提供一下几种:

Vue使用vue-cli创建项目

也可以使用自定义的模板,可以来自远端托管仓库或本地。

选用webpack模板项目:https://github.com/vuejs-templates/webpack

二、Mint_UI框架的使用

1.完整引入

在 main.js 中写入以下内容:

import Vue from 'vue'
import MintUI from 'mint-ui'
import 'mint-ui/lib/style.css'
import App from './App.vue'

Vue.use(MintUI)

new Vue({
 el: '#app',
 render: h => h(App)
})

以上代码便完成了 Mint UI 的引入。需要注意的是,样式文件需要单独引入。

2.按需引入

安装 babel-plugin-component:

npm install babel-plugin-component -D

将 .babelrc 修改为:

{
 "presets": [
  ["es2015", { "modules": false }]
 ],
 "plugins": [["component", [
  {
   "libraryName": "mint-ui",
   "style": true
  }
 ]]]
}

引入方式如下

import Vue from 'vue'
import { Button, Cell } from 'mint-ui'
import App from './App.vue'

Vue.component(Button.name, Button)
Vue.component(Cell.name, Cell)
/* 或写为
 * Vue.use(Button)
 * Vue.use(Cell)
 */

new Vue({
 el: '#app',
 render: h => h(App)
})

创建项目过程中有一下几个问题:

1.本地开发状态启动项目时,常会有代码空行、分号报错的问题。 原因:在创建项目时,选择了使用eslint语法校验。

2.引入样式报错问题,babel无法编译css文件。

Module not found: Error: Cannot resolve module 'mint-ui/style.css'

原因:全局引入需要引入样式,如果在.babelrc中设置过按需引入,则不要再专门引入css.

Vue使用vue-cli创建项目

3.另外引入的组件要在自定义组件中注册,组件中嵌套的组件也要进行引用和注册。

4.非渲染dom组件无需写在模板内,也无需注册,可以直接调用使用。比如load的Indicator

Vue使用vue-cli创建项目

三、vue-router的使用

github地址:https://github.com/vuejs/vue-router

在入口文件main.js中引入

import VueRouter from 'vue-router';
Vue.use(VueRouter);
//然后实例化一个router
const router = new VueRouter({
mode: 'history',
routes: routes
});

rotues是自己分配的路由设置;

四、使用vuex进行状态管理

vue的状态管理工具 vuex

下面简单介绍下vuex各个部分的概念

  • state是一个全局的状态存储,数据会存储在其中,vue组件可以直接访问其中的值,但是只可以读,不可以进行写操作
  • getter,有些时候我们需要对获取的数据进行加工,而不是直接获取state中的数据,这时候可以通过getter定义函数,返回对应的数据
  • mutations是vuex中唯一一个可以修改数据的地方,mutations可以定义事件函数,在vue组件中可以通过commit发射事件,调用函数。需要注意的是,mutations中的操作必须是同步的,不可以存在异步操作的情况。
  • actions和 mutation比较相似,不同的是actions中不直接修改state,而是通过commit调用mutations修改数据,而且actions中可以存在异步处理逻辑

使用vuex需要在Vue.use中引入,然后实例化一个Vuex.Store对象就可以了,对象中需要定义state,actions,mutations,getters等内容,这样子就可以建立一个全局的状态管理机制,可以从应用的顶端去处理数据,各个组件中对数据进行操作也是通过事件直接传递到Vuex中进行数据更新,然后再进行响应到其他使用同个数据的组件中,进行视图更新。

Vue使用vue-cli创建项目

Vue使用vue-cli创建项目

Vue使用vue-cli创建项目

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

Javascript 相关文章推荐
javascript jQuery $.post $.ajax用法
Jul 09 Javascript
Javascript排序算法之合并排序(归并排序)的2个例子
Apr 04 Javascript
JQuery遍历json数组的3种方法
Nov 08 Javascript
js实现不重复导入的方法
Mar 02 Javascript
详解AngularJS控制器的使用
Mar 09 Javascript
通过JS和PHP两种方法判断用户请求时使用的浏览器类型
Sep 01 Javascript
Vue 2.0的数据依赖实现原理代码简析
Jul 10 Javascript
js实现1,2,3,5数字按照概率生成
Sep 12 Javascript
如何使node也支持从url加载一个module详解
Jun 05 Javascript
vuejs点击class变化的实例
Sep 05 Javascript
JS数组扁平化(flat)方法总结详解
Jun 24 Javascript
使用node.JS中的url模块解析URL信息
Feb 06 Javascript
vue 里面使用axios 和封装的示例代码
Sep 01 #Javascript
ionic2懒加载配置详解
Sep 01 #Javascript
javascript 中事件冒泡和事件捕获机制的详解
Sep 01 #Javascript
Vue的Class与Style绑定的方法
Sep 01 #Javascript
Angular中封装fancyBox(图片预览)遇到问题小结
Sep 01 #Javascript
BootStrap模态框和select2合用时input无法获取焦点的解决方法
Sep 01 #Javascript
Angularjs实现上传图片预览功能
Sep 01 #Javascript
You might like
php实现加减法验证码代码
2014/02/14 PHP
PHPMailer的主要功能特点和简单使用说明
2014/02/17 PHP
PHP下载大文件失败并限制下载速度的实例代码
2019/05/10 PHP
搭建PhpStorm+PhpStudy开发环境的超详细教程
2020/09/17 PHP
javascript[js]获取url参数的代码
2007/10/17 Javascript
基于JQuery的cookie插件
2010/04/07 Javascript
javascript代码加载优化方法
2011/01/30 Javascript
DOM基础教程之使用DOM + Css
2015/01/20 Javascript
jQuery实现数秒后自动提交form的方法
2015/03/05 Javascript
Bootstrap入门书籍之(四)菜单、按钮及导航
2016/02/17 Javascript
JS基于ocanvas插件实现的简单画板效果代码(附demo源码下载)
2016/04/05 Javascript
jquery uploadify如何取消已上传成功文件
2017/02/08 Javascript
NW.js 简介与使用方法
2018/02/01 Javascript
JavaScript设计模式之单例模式原理与用法实例分析
2018/07/26 Javascript
基于vue2的canvas时钟倒计时组件步骤解析
2018/11/05 Javascript
js canvas实现画图、滤镜效果
2018/11/27 Javascript
详解Vue-axios 设置请求头问题
2018/12/06 Javascript
实例讲解v-if和v-show的区别
2019/01/31 Javascript
微信小程序单选框自定义赋值
2020/05/26 Javascript
vue 通过绑定事件获取当前行的id操作
2020/07/27 Javascript
python操作kafka实践的示例代码
2019/06/19 Python
Python实现Singleton模式的方式详解
2019/08/08 Python
浅谈python中频繁的print到底能浪费多长时间
2020/02/21 Python
python继承threading.Thread实现有返回值的子类实例
2020/05/02 Python
使用Python获取爱奇艺电视剧弹幕数据的示例代码
2021/01/12 Python
删除pycharm鼠标右键快捷键打开项目的操作
2021/01/16 Python
HTML5 video循环播放多个视频的方法步骤
2020/08/06 HTML / CSS
C面试题
2015/10/08 面试题
护士实习生自我鉴定范文
2013/12/10 职场文书
团委竞选演讲稿
2014/04/24 职场文书
神龙架导游词
2015/02/11 职场文书
2015年复活节活动总结
2015/02/27 职场文书
python实战之90行代码写个猜数字游戏
2021/04/22 Python
教你怎么用Python处理excel实现自动化办公
2021/04/30 Python
django中websocket的具体使用
2022/01/22 Python
vue如何使用模拟的json数据查看效果
2022/03/31 Vue.js