深入淺析Vue組件開發(fā)
前言
這里講的主要是想談談基于Vue的一個組件開發(fā)。不得不說的一點就是,在實際的Vue項目中,頁面中每一個小塊都是由一個個組件(.vue文件)組成,經(jīng)過抽離后,然后再合并一起組成一個頁面。由于上家公司我負責多的是可視化這一塊的開發(fā),這邊我也將帶著大家進行一個Vue項目中的可視化組件的開發(fā),這里用到的框架將是主流的可視化框架highcharts。
一、Vue環(huán)境的搭建
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官網(wǎng),然后下載對應自己電腦系統(tǒng)的版本

安裝成功,安裝vue
npm install vue
最后查看一下自己node,npm,vue版本(失敗的話自行百度windows系統(tǒng)如何安裝node)。下圖是我目前node,npm及vue的版本
如果這里出問題了,請全局安裝vue-cli
npm install -g vue-cli
二、Vue項目初始化
進入你需要搭建Vue項目的目錄下執(zhí)行
vue init webpack my-vue-component
配置就按下圖進行選擇

然后進入到my-vue-component目錄執(zhí)行
# 下載項目的版本依賴 npm install
由于我家里的網(wǎng)絡,需要翻墻的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的可視化組件開發(fā)了
1、首先打開自己初始化好的項目(這里我用的是sublime,實際開發(fā)中我用的是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架子搭好后,開始創(chuàng)建chart-options目錄,里面創(chuàng)建一個options.js用來存放模擬的chart數(shù)據(jù)
這里我模擬寫了一個柱狀圖的數(shù)據(jù)
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組件模擬數(shù)據(jù)
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組件也引入成功,我們直接看一下最后頁面中顯示的效果吧

這里需要說明一點的就是對于所有highchars組件的適用度。大家通過看我寫的模擬數(shù)據(jù)也可以看出來,這里我是把一些通用的屬性給直接忽略了。如果實際項目的開發(fā)中需要的話,大家可以把通用的一些屬性的數(shù)據(jù)直接寫到chart.vue文件中。通過props驗證,寫好default默認值作為通用屬性。直接給大家看下我實際開發(fā)當中對于一些通用屬性的處理吧

這里還是需要看你們項目的需求,然后制定一套屬于自己的通用的屬性。然后再單獨對每個組件進行操作。
以上所述是小編給大家介紹的Vue組件開發(fā),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
詳解vue-cli 3.0 build包太大導致首屏過長的解決方案
這篇文章主要介紹了詳解vue-cli 3.0 build包太大導致首屏過長的解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
關(guān)于element-ui?select?下拉框位置錯亂問題解決
這篇文章主要介紹了關(guān)于element-ui?select?下拉框位置錯亂問題解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
Element-UI中<el-cascader?/>回顯失敗問題的完美解決
我們在使用el-cascader控件往數(shù)據(jù)庫保存的都是最后一級的數(shù)據(jù),那如果再次編輯此條數(shù)據(jù)時,直接給el-cascader傳入最后一級的數(shù)據(jù),它是不會自動勾選的,下面這篇文章主要給大家介紹了關(guān)于Element-UI中<el-cascader?/>回顯失敗問題的完美解決辦法,需要的朋友可以參考下2023-01-01

