uniapp使用ucharts基本折线

这个是插件主页

https://ext.dcloud.net.cn/plugin?id=271

导入项目之后,项目就会出现uni_modules目录
在这里可以生成代码

https://demo.ucharts.cn/

代码
<template>
	<view class="qiun-columns">
		<view class="qiun-charts" >
			<canvas canvas-id="canvasLineA" id="canvasLineA" class="charts" @touchstart="touchLineA"></canvas>
		</view>
	</view>
</template>

<script>
	// 引入uCharts 方法组件。
	import uCharts from '@/uni_modules/qiun-data-charts/js_sdk/u-charts/u-charts.js';
	// 定义全局变量
	var _self;
	var canvaLineA=null;
	var chartData = {
    "categories": [
        "2016",
        "2017",
        "2018",
        "2019",
        "2020",
        "2021"
    ],
    "series": [
        {
            "name": "成交量A",
            "data": [
                35,
                8,
                25,
                37,
                4,
                20
            ]
        },
        {
            "name": "成交量B",
            "data": [
                26,
                10,
                65,
                160,
                44,
                68
            ]
        }
    ]
};
	export default {
		data() {
			return {
				cWidth:'',
				cHeight:'',
				pixelRatio:1,
			}
		},
		// 页面加载执行的函数
		onLoad() {
			_self = this;
			// uni.upx2px(750) 这是uni-app自带的自适应,以750的尺寸为基准。动态变化
			this.cWidth=uni.upx2px(750);
			this.cHeight=uni.upx2px(500);
			
			this.showLineA("canvasLineA",chartData);
		},
		methods: {
			// 展示图标的函数 接收参数,一个块的id,一个数据
			showLineA(canvasId,chartData){
				canvaLineA=new uCharts({
					$this:_self,
					canvasId: canvasId,
					context: uni.createCanvasContext(canvasId, _self),
					// 图标类型
					type: 'line',
					fontSize:11,
					legend:{show:true},
					dataLabel:false,
					dataPointShape:true,
					background:'#FFFFFF',
					pixelRatio:_self.pixelRatio,
					categories: chartData.categories,
					series: chartData.series,
					animation: true,
					// x轴显示的内容
					xAxis: {
						type:'grid',
						gridColor:'#CCCCCC',
						gridType:'dash',
						dashLength:8
					},
					// y轴显示的内容
					yAxis: {
						gridType:'dash',
						gridColor:'#CCCCCC',
						dashLength:8,
						splitNumber:5,
						min:10,
						max:180,
						format:(val)=>{return val.toFixed(0)+'元'}
					},
					width: _self.cWidth*_self.pixelRatio,
					height: _self.cHeight*_self.pixelRatio,
					extra: {
						line:{
							type: 'straight'
						}
					}
				});
				
			},
			// 点击图表显示的内容
			touchLineA(e) {
				// 使用声明的变量canvaLineA
				canvaLineA.showToolTip(e, {
					format: function (item, category) {
						return category + ' ' + item.name + ':' + item.data 
					}
				});
			}
		}
	}
</script>

<style scoped>
	/*样式的width和height一定要与定义的cWidth和cHeight相对应*/
	.qiun-charts {
		width: 750upx;
		height: 500upx;
		background-color: #FFFFFF;
	}
	
	.charts {
		width: 750upx;
		height: 500upx;
		background-color: #FFFFFF;
	}
</style>
结果

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想在 uniapp h5 中使用 uCharts 折线图进行多个特殊标点,则可以通过以下步骤实现: 1. 在您的页面中引入 uCharts 组件,并在 data 中定义折线图的配置项,如下所示: ``` <template> <u-charts :opts="opts" /> </template> <script> import uCharts from '@/components/u-charts/u-charts.vue' export default { components: { uCharts }, data() { return { opts: { type: 'line', categories: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], series: [ { name: 'line', data: [10, 20, 30, 40, 50, 60, 70], color: '#FF0000' } ], xAxis: { disableGrid: true }, yAxis: { title: 'Value' } } } } } </script> ``` 2. 在您的页面中定义特殊标点的数据,并将其添加到配置项的 series 数组中,如下所示: ``` <template> <u-charts :opts="opts" /> </template> <script> import uCharts from '@/components/u-charts/u-charts.vue' export default { components: { uCharts }, data() { return { opts: { type: 'line', categories: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], series: [ { name: 'line', data: [10, 20, 30, 40, 50, 60, 70], color: '#FF0000' }, { name: 'point', data: [ { name: 'Mon', value: 10, color: '#00FF00', pointShape: 'diamond', pointSize: 10 }, { name: 'Wed', value: 30, color: '#0000FF', pointShape: 'triangle', pointSize: 10 }, { name: 'Sat', value: 60, color: '#FF00FF', pointShape: 'circle', pointSize: 10 } ] } ], xAxis: { disableGrid: true }, yAxis: { title: 'Value' } } } } } </script> ``` 在上述代码中,我们定义了一个名为 'point' 的 series,其中包含三个特殊标点数据,分别对应星期一、三和六。这些特殊标点的颜色、形状和大小都可以自定义。 3. 最后,您可以根据需要进一步调整折线图的样式和显示效果,以满足您的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值