深入浅析Vue组件开发


Posted in Javascript onNovember 25, 2016

前言

这里讲的主要是想谈谈基于Vue的一个组件开发。不得不说的一点就是,在实际的Vue项目中,页面中每一个小块都是由一个个组件(.vue文件)组成,经过抽离后,然后再合并一起组成一个页面。由于上家公司我负责多的是可视化这一块的开发,这边我也将带着大家进行一个Vue项目中的可视化组件的开发,这里用到的框架将是主流的可视化框架highcharts。

一、Vue环境的搭建

1、Mac用户

首先安装包管理homebrew

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

再安装node

brew install node

安装vue

npm install vue

2、windows用户

进入nodejs官网,然后下载对应自己电脑系统的版本

深入浅析Vue组件开发

安装成功,安装vue

npm install vue

最后查看一下自己node,npm,vue版本(失败的话自行百度windows系统如何安装node)。下图是我目前node,npm及vue的版本

如果这里出问题了,请全局安装vue-cli

npm install -g vue-cli

二、Vue项目初始化

进入你需要搭建Vue项目的目录下执行

vue init webpack my-vue-component

配置就按下图进行选择

深入浅析Vue组件开发

然后进入到my-vue-component目录执行

# 下载项目的版本依赖
npm install

由于我家里的网络,需要翻墙的npm根本动不了,这里我用的是淘宝镜像进行的依赖安装,没有淘宝镜像的先安装一下吧(实际项目中还是需要用npm,毕竟cnpm会忽略下载一些依赖的)

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

安装完成,启动项目

npm run dev

OK,至此,Vue项目便搭建好了。

三、highchars的导入与搭建

首先通过cnpm进行highchars的导入

cnpm install highcharts --save

导入完成后就可以进行highchars的可视化组件开发了

1、首先打开自己初始化好的项目(这里我用的是sublime,实际开发中我用的是atom)

在初始化好了的components目录下新建一个chart.vue文件

接下来搭建chart组件的架子

<template>
<div class="x-bar">
<div :id="id"
:option="option"></div>
</div>
</template>
<script>
import HighCharts from 'highcharts'
export default {
// 验证类型
props: {
id: {
type: String
},
option: {
type: Object
}
},
mounted() {
HighCharts.chart(this.id,this.option)
}
}
</script>

chart架子搭好后,开始创建chart-options目录,里面创建一个options.js用来存放模拟的chart数据

这里我模拟写了一个柱状图的数据

module.exports = {
bar: {
chart: {
type: 'bar',
},
series: [{
data: [50, 235, 809, 947]
}]
}
}

四、引用chart组件

这里直接就把引用写到App.vue这么一个接口文件中吧

<template>
<div id="app">
<x-chart :id="id" :option="option"></x-chart>
</div>
</template>
<script>
// 导入chart组件
import XChart from 'components/chart.vue'
// 导入chart组件模拟数据
import options from './chart-options/options'
export default {
name: 'app',
data() {
let option = options.bar
return {
id: 'test',
option: option
}
},
components: {
XChart
}
}
</script>
<style>
#test {
width: 400px;
height: 400px;
margin: 40px auto;
}
</style>

到这里,chart组件也引入成功,我们直接看一下最后页面中显示的效果吧

深入浅析Vue组件开发

这里需要说明一点的就是对于所有highchars组件的适用度。大家通过看我写的模拟数据也可以看出来,这里我是把一些通用的属性给直接忽略了。如果实际项目的开发中需要的话,大家可以把通用的一些属性的数据直接写到chart.vue文件中。通过props验证,写好default默认值作为通用属性。直接给大家看下我实际开发当中对于一些通用属性的处理吧

深入浅析Vue组件开发

这里还是需要看你们项目的需求,然后制定一套属于自己的通用的属性。然后再单独对每个组件进行操作。

以上所述是小编给大家介绍的Vue组件开发,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
用js 让图片在 div或dl里 居中,底部对齐
Jan 21 Javascript
javascript 表单的友好用户体现
Jan 07 Javascript
jQuery之网页换肤实现代码
Apr 30 Javascript
js中使用DOM复制(克隆)指定节点名数据到新的XML文件中的代码
Jul 27 Javascript
鼠标移入移出事件改变图片的分辨率的两种方法
Dec 17 Javascript
javascript:window.open弹出窗口的位置问题
Mar 18 Javascript
jQuery选择器全集详解
Nov 24 Javascript
2种jQuery 实现刮刮卡效果
Feb 01 Javascript
jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween
Dec 03 Javascript
JavaScript实现图片懒加载(Lazyload)
Nov 28 Javascript
浅谈js函数的多种定义方法与区别
Nov 29 Javascript
深入理解ES7的async/await的用法
Sep 09 Javascript
javascript中href和replace的比较(详解)
Nov 25 #Javascript
移动适配的几种方案(三种方案)
Nov 25 #Javascript
利用JS判断字符串是否含有数字与特殊字符的方法小结
Nov 25 #Javascript
利用JS屏蔽页面中的Enter按键提交表单的方法
Nov 25 #Javascript
JavaScript实现点击按钮复制指定区域文本(推荐)
Nov 25 #Javascript
Bootstrap实现带暂停功能的轮播组件(推荐)
Nov 25 #Javascript
Bootstrap文件上传组件之bootstrap fileinput
Nov 25 #Javascript
You might like
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
PHP如何实现跨域
2016/05/30 PHP
Yii2简单实现多语言配置的方法
2016/07/23 PHP
jQuery 常见开发使用技巧总结
2009/12/26 Javascript
深入理解Javascript动态方法调用与参数修改的问题
2013/12/10 Javascript
JS 操作Array数组的方法及属性实例解析
2014/01/08 Javascript
使用jQuery设置disabled属性与移除disabled属性
2014/08/21 Javascript
JavaScript开发人员的10个关键习惯小结
2014/12/05 Javascript
jQuery的观察者模式详解
2014/12/22 Javascript
基于Node.js实现nodemailer邮件发送
2016/01/26 Javascript
jQuery实现的自定义滚动条实例详解
2016/09/20 Javascript
使用bootstrap实现多窗口和拖动效果
2016/09/22 Javascript
JS查找英文文章中出现频率最高的单词
2017/03/20 Javascript
详解在Vue中有条件地使用CSS类
2017/09/30 Javascript
Vue.js实现分页查询功能
2020/11/15 Javascript
原生JS实现ajax与ajax的跨域请求实例
2017/12/01 Javascript
学习JS中的DOM节点以及操作
2018/04/30 Javascript
Vue中CSS动画原理的实现
2019/02/13 Javascript
Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)
2020/03/11 Javascript
vue-autoui自匹配webapi的UI控件的实现
2020/03/20 Javascript
Javascript查看大图功能代码实现
2020/05/07 Javascript
Vue Elenent实现表格相同数据列合并
2020/11/30 Vue.js
[00:58]2016年国际邀请赛勇士令状宣传片
2016/06/01 DOTA
python3使用pyqt5制作一个超简单浏览器的实例
2017/10/19 Python
Python中max函数用于二维列表的实例
2018/04/03 Python
python调用webservice接口的实现
2019/07/12 Python
python支持多继承吗
2020/06/19 Python
详解java调用python的几种用法(看这篇就够了)
2020/12/10 Python
美国批发零售网站:GearXS
2016/07/26 全球购物
台湾东南旅游社网站:东南旅游
2019/02/11 全球购物
新浪网技术部笔试题
2016/08/26 面试题
List, Set, Map是否继承自Collection接口?
2016/05/16 面试题
中专生求职自荐信范文
2013/12/22 职场文书
大学生第一学年自我鉴定2015
2014/09/28 职场文书
个人作风建设自查报告
2014/10/22 职场文书
七年级思品教学反思
2016/02/20 职场文书