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 相关文章推荐
textarea的value是html文件源代码,存成html文件的代码
Apr 20 Javascript
JS实现判断碰撞的方法
Feb 11 Javascript
JavaScript实现的链表数据结构实例
Apr 02 Javascript
jQuery实现滚动切换的tab选项卡效果代码
Aug 26 Javascript
老生常谈ES6中的类
Jul 31 Javascript
微信小程序block的使用教程
Apr 01 Javascript
Vue ElementUi同时校验多个表单(巧用new promise)
Jun 06 Javascript
实例详解ztree在vue项目中使用并且带有搜索功能
Aug 24 Javascript
node全局变量__dirname与__filename的区别
Jan 14 Javascript
JavaScript禁用右键单击优缺点分析
Jan 20 Javascript
Vue+Node服务器查询Mongo数据库及页面数据传递操作实例分析
Dec 20 Javascript
JS实现公告上线滚动效果
Jan 10 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 数组教程 定义数组
2009/10/23 PHP
PHP使用get_headers函数判断远程文件是否存在的方法
2014/11/28 PHP
教你在header中隐藏php的版本信息
2016/08/10 PHP
$.ajax返回的JSON无法执行success的解决方法
2011/09/09 Javascript
js网页中的(运行代码)功能实现思路
2013/02/04 Javascript
对js关键字命名的疑问介绍
2014/04/25 Javascript
js+css实现超简洁的二级下拉菜单效果代码
2015/09/07 Javascript
js+css简单实现网页换肤效果
2015/12/29 Javascript
详解Node.js模块间共享数据库连接的方法
2016/05/24 Javascript
jquery基本选择器匹配多个元素的实现方法
2016/09/05 Javascript
详谈JavaScript的闭包及应用
2017/01/17 Javascript
Angular.js前台传list数组由后台spring MVC接收数组示例代码
2017/07/31 Javascript
Node.js调用fs.renameSync报错(Error: EXDEV, cross-device link not permitted)
2017/12/27 Javascript
vue-cli项目根据线上环境分别打出测试包和生产包
2018/05/23 Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
2020/07/21 Javascript
[48:24]完美世界DOTA2联赛PWL S3 Forest vs INK ICE 第一场 12.09
2020/12/12 DOTA
python实现各进制转换的总结大全
2017/06/18 Python
python实现二叉查找树实例代码
2018/02/08 Python
python实现k-means聚类算法
2018/02/23 Python
python如何实现视频转代码视频
2019/06/17 Python
Python 实现遥感影像波段组合的示例代码
2019/08/04 Python
python构建指数平滑预测模型示例
2019/11/21 Python
python3连接mysql获取ansible动态inventory脚本
2020/01/19 Python
python分别打包出32位和64位应用程序
2020/02/18 Python
Python datetime 格式化 明天,昨天实例
2020/03/02 Python
有关pycharm登录github时有的时候会报错connection reset的问题
2020/09/15 Python
Python入门基础之数字字符串与列表
2021/02/01 Python
HTML5几个设计和修改的页面范例分享
2015/09/29 HTML / CSS
世界排名第一的万圣节服装店:Spirit Halloween
2018/10/16 全球购物
中国汽车租赁行业头部企业:一嗨租车
2019/05/16 全球购物
银行演讲稿范文
2014/01/03 职场文书
年终考核评语
2014/01/19 职场文书
介绍信模板
2015/01/31 职场文书
行为规范主题班会
2015/08/13 职场文书
使用 JavaScript 制作页面效果
2021/04/21 Javascript
Python实现天气查询软件
2021/06/07 Python