国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Uni-App微信小程序平臺兼容常用圖表庫

開發 前端
對于uni-app用戶來說,如若使用圖表能力,只能去dcloud社區插件 (https://ext.dcloud.net.cn/) 中搜尋,亦或是自己動手。下面來看一下,如何自己封裝組件使用這些h5圖表庫。

?前言?

從使用場景上來說,這篇更應該看作是如何在微信小程序中使用常用h5圖表庫 (antv/f2、echarts等) 。但是得益于uni-app的跨平臺能力,能讓我們使用更加熟悉的vue框架來實現微信小程序的開發。對于uni-app用戶來說,如若使用圖表能力,只能去dcloud社區插件 (https://ext.dcloud.net.cn/) 中搜尋,亦或是自己動手。下面來看一下,如何自己封裝組件使用這些h5圖表庫。

?antv/f2?

由于新的4.x版本使用的是jsx語法,不是很習慣。這里演示的是3.x (https://f2-v3.antv.vision/zh/docs/tutorial/getting-started) 版本。在官方文檔中我們很容易發現:F2 是基于 CanvasRenderingContext2D (https://developer.mozilla.org/zh-CN/docs/Web/API/CanvasRenderingContext2D) 的標準接口繪制的,所以只要能提供標準 CanvasRenderingContext2D 接口的實現對象,F2就能進行圖表繪制。

因為在小程序中給的 context? 對象不是標準的 CanvasRenderingContext2D , 所以封裝的核心思路是將 context? 和 CanvasRenderingContext2D 對齊,所以 F2 針對支付寶和微信這2個常見的場景做了一層 context 的對齊,詳情可見:https://github.com/antvis/f2-context,其他小程序也可以按同樣的思路封裝。

當然微信小程序,f2已經兼容過,在使用的時候可以省略這一步。

首先在src (基于vue-cli) 目錄下components文件夾下新建組件f2-uni,在f2-uni.vue文件的template中添加。

<template>
<canvas
type="2d"
class="f2-canvas"
@touchstart="touchStart"
@touchmove="touchMove"
@touchend="touchEnd"
>
</canvas>
</template>

給容器設定個寬高。

<style lang="less">
.f2-canvas {
width: 100%;
height: 600rpx;
}
</style>

組件接收一個參數onInit,用來接收F2構造方法和config。

props: {
onInit: {
type: Function,
default: () => {}
}
},

注冊組件初始化的時候調用方法,從這里也能看出,小程序與h5在dom操作時選擇器方法的差別。

const query = uni.createSelectorQuery().in(this)
query.select('.f2-canvas')
.fields({
node: true,
size: true
})
.exec(res => {
const { node, width, height } = res[0]
const context = node.getContext('2d') // 微信基礎庫2.7.0 以上支持
const pixelRatio = uni.getSystemInfoSync().pixelRatio
// 高清設置
node.width = width * pixelRatio
node.height = height * pixelRatio

const config = { context, width, height, pixelRatio }
const chart = this.onInit(F2, config)
if (chart) {
this.canvasEl = chart.get('el')
}
})

注:canvas.getContext 基礎庫2.7.0開始支持,如果對兼容性有要求可參考官方兼容處理 (https://developers.weixin.qq.com/miniprogram/dev/framework/compatibility.html) 。

touch事件處理 (其他兩個同理) 。

function wrapEvent (e) {
if (!e) return
if (!e.preventDefault) {
e.preventDefault = function () {}
}
return e
}
touchStart (e) {
const canvasEl = this.canvasEl
if (!canvasEl) {
return
}
canvasEl.dispatchEvent('touchstart', wrapEvent(e))
}

至此組件主體封裝已完成,在頁面中使用。

<f2-uni class="f2-chart" :onInit="onInitChart"></f2-uni>
methods: {
onInitChart: (F2Constructor, config) => {
const chart = new F2Constructor.Chart(config)
const data = [
{ value: 63.4, city: 'New York', date: '2011-10-01' },
{ value: 62.7, city: 'Alaska', date: '2011-10-01' },
{ value: 72.2, city: 'Austin', date: '2011-10-01' },
{ value: 58, city: 'New York', date: '2011-10-02' },
{ value: 59.9, city: 'Alaska', date: '2011-10-02' },
{ value: 67.7, city: 'Austin', date: '2011-10-02' },
{ value: 53.3, city: 'New York', date: '2011-10-03' },
{ value: 59.1, city: 'Alaska', date: '2011-10-03' },
{ value: 69.4, city: 'Austin', date: '2011-10-03' }
]
chart.source(data, {
date: {
range: [0, 1],
type: 'timeCat',
mask: 'MM-DD'
},
value: {
max: 300,
tickCount: 4
}
})
chart.area().position('date*value').color('city').adjust('stack')
chart.line().position('date*value').color('city').adjust('stack')
chart.render()
// 注意:需要把chart return 出來
return chart
}
}
}

成功渲染出示例圖表。

圖片

本文旨在提供思路,具體封裝可以更加靈活易用。

完整代碼 (https://code.juejin.cn/pen/7113852538541047821) 。

?echarts?

與上面同理,主要針對小程序的dom選擇器和canvas context做一些兼容處理。具體封裝可參考dcloud社區中一款不錯的插件 echarts for uniapp(https://ext.dcloud.net.cn/plugin?id=8017)下載插件zip包,可查看源碼。

如果只在微信小程序平臺編譯使用,且條件編譯不生效,我提煉了純凈版:代碼片段 (https://code.juejin.cn/pen/7113871812777230372)。

責任編輯:姜華 來源: 微醫大前端技術
相關推薦

2025-01-23 16:08:56

2021-09-28 09:30:18

uni-appVue 3.0uniCloud

2022-07-29 11:03:47

VueUni-app

2018-01-25 22:26:10

微信小程序app

2023-01-05 09:01:05

UI組件庫微信

2017-05-08 15:03:07

微信小程序開發實戰

2021-05-15 09:10:58

微信小程序開發者

2016-11-22 11:23:52

微信小程序騰訊微信

2016-11-04 10:49:48

微信小程序

2016-09-27 15:40:58

微信程序前端

2016-09-27 16:38:24

JavaScript微信Web

2021-06-10 10:51:27

程序基礎架構

2016-10-20 21:02:12

微信小程序javascript

2016-09-28 18:10:59

微信程序MINA

2017-06-09 12:58:20

微信小程序架構分析

2017-06-09 10:06:54

微信小程序架構分析

2017-01-09 10:01:49

微信小程序

2016-11-04 10:31:49

微信程序指南

2017-06-09 10:40:00

微信小程序架構分析
點贊
收藏

51CTO技術棧公眾號

国产精品久久久久久麻豆一区软件| 国产午夜福利视频在线观看| www.日日操| 欧美人体视频xxxxx| 国产999精品久久久久久| 日本亚洲欧洲色| av小次郎在线| 亚洲六月丁香色婷婷综合久久 | 96视频在线观看欧美| 国产精品伦一区| 蜜桃导航-精品导航| 精品久久久久久久久久久下田| 欧美成人vps| 成人18在线| 国产精品短视频| 九九精品视频在线| 在线观看黄色小视频| 成人精品国产福利| 亚洲精品影院| 黑人一区二区| 68精品久久久久久欧美| 色网在线免费观看| 欧美亚洲一区二区在线观看| av线上观看| 国产亚洲成av人在线观看导航| 茄子视频成人在线观看| 成人情趣视频网站| 欧美成aaa人片免费看| 久久婷婷国产精品| 亚洲激情av| 国产精品亚发布| av中文一区| 国产精品视频网| 国内成人自拍| 亚洲午夜性刺激影院| 成人自拍视频网| 欧美日韩aaaaa| 久久伊伊香蕉| 这里只有精品电影| 精品众筹模特私拍视频| 亚洲欧美国产制服动漫| 波多野结衣在线观看| 日韩精品极品视频| 91精品在线免费视频| 欧美日韩成人在线播放| 妖精视频一区二区三区| 中文字幕成人精品久久不卡| 亚洲精品在线播放| 国产精品大片wwwwww| 俺要去色综合狠狠| 91av在线影院| 亚洲视频高清| 日本人妻伦在线中文字幕| 麻豆91在线看| 狠狠色一日本高清视频| 91麻豆视频网站| www午夜视频| 久久黄色影院| 偷拍盗摄高潮叫床对白清晰| 蜜桃久久av一区| 国产乱码精品一区二区三区卡 | 欧美一区二区成人| 黄色精品视频网站| 成人网在线视频| 成人在线一区二区三区| 国产免费黄视频在线观看| 717成人午夜免费福利电影| 在线免费成人| 7777奇米亚洲综合久久| 国产精品99久| 日韩成人手机在线| 欧日韩精品视频| 日本免费在线观看| 欧美贵妇videos办公室| 狠狠色2019综合网| 亚州av中文字幕在线免费观看| 久久九九久久九九| 毛片在线视频| 97超碰人人看人人| www久久精品| 色视频免费在线观看| 少妇高潮久久77777| 欧美黑白配在线| 蜜桃传媒视频第一区入口在线看| 66视频精品| wwwwxxxx日韩| 日韩欧美一区二区免费| 18成人免费观看视频| 国产对白在线正在播放| 欧美制服第一页| 丰满少妇又爽又紧又丰满69| 亚洲欧美伊人| 精品在线视频一区二区| 欧美日韩国产在线观看网站 | 红桃成人av在线播放| 天堂中文资源在线| 精品国产乱码久久久久久蜜柚| 亚洲mv在线观看| 久久一区激情| 日本黄色免费在线| 99视频免费| 国产尤物91| www.亚洲一区| 中文字幕欧美激情一区| 日本精品三区| wwww在线观看免费视频| 国产精品三级一区二区| 青青久久av北条麻妃海外网| 3751色影院一区二区三区| 成人丝袜高跟foot| 亚洲色图88| 992tv国产精品成人影院| 91久热免费在线视频| 欧美精品一卡二卡| 成人aa视频在线观看| 综合天堂av久久久久久久| av资源一区| 噼里啪啦在线中文观看| av免费观看国产| 92国产精品久久久久首页| 日韩一级免费观看| 99re这里只有精品6| 亚洲综合激情在线| 高清精品视频| free欧美| 国产原创av在线| 无码人妻丰满熟妇区毛片| 精品一区二区久久久久久久网站| 欧美一级淫片aaaaaaa视频| 在线播放日韩专区| 欧美午夜一区二区| 日本一区二区成人| 不卡视频一二三| 精品在线你懂的| 亚洲性色视频| 亚洲自拍欧美色图| 69久久夜色精品国产69乱青草| 亚洲欧美成人在线| 欧美午夜精品电影| 色88888久久久久久影院野外| 国产女人水真多18毛片18精品视频 | 天堂成人在线| 国产精品久久久久久久久久久久冷| 中文字幕精品在线| 亚洲国产高潮在线观看| 欧美一级理论片| 专区另类欧美日韩| **欧美大码日韩| 成人丝袜高跟foot| 国内精品久久久久影院薰衣草 | 日本一区二区三区视频视频| 99国产精品久久久久久久久久久 | 亚洲一区二区av电影| 欧美日韩性生活视频| 欧美主播一区二区三区美女| 欧美乱熟臀69xxxxxx| 欧美成人a∨高清免费观看| 欧美视频中文一区二区三区在线观看| 婷婷中文字幕综合| 欧美视频国产精品| 日韩欧美中文字幕精品| 欧美一区二区三区免费观看视频| 欧美日韩视频不卡| 国产亚洲精品成人av久久ww| 最近的2019中文字幕免费一页| 亚洲天堂男人的天堂| 热门国产精品亚洲第一区在线| 热久久99这里有精品| 国产美女精品久久久| 免费在线黄网站| 国产女呦网站| 日本高清视频在线观看| 九色porny自拍视频在线播放| 国产性xxxx18免费观看视频| 2020中文字字幕在线不卡| 国产成人在线视频免费观看| 免费看久久久| 成人精品电影| 久久国产夜色精品鲁鲁99| 亚洲一区二区三区中文字幕| 欧美刺激午夜性久久久久久久| 91精品国产高清| www.一区二区.com| 羞羞视频在线观看| 伊人久久大香线蕉综合影院首页| 麻豆mv在线观看| 精品一级毛片| 99久久精品国产观看| 337p亚洲精品色噜噜噜| 日韩丝袜美女视频| 91在线免费观看网站| 鲁一鲁一鲁一鲁一av| 182在线视频观看| 午夜天堂精品久久久久| 亚洲一区二区在线免费观看视频| 亚洲精品视频免费| 特级黄色录像片| 久久野战av| 91亚洲精品乱码久久久久久蜜桃 | 色综合天天做天天爱|