Vue CLI——Vue Router路由 & swiper插件 & Echarts使用

一、Vue Router路由

Vue Router是Vue.js官方的路由管理器,可以实现页面的跳转。

1、安装
npm install vue-router

2、 导入vue-router
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)

3、创建路由器
// 导入页面组件
import Home from './pages/Home.vue'
import List from './pages/List.vue'

// 创建路由器对象
export default new VueRouter({
// 定义当前路由器对象管理的路由信息
routes: [
// 每一条路由信息,就是一个对象
{
// 路由路径
path:'/home',
// 路由名称
name:'home',
// 路由组件
component:Home
},
{
path: '/list',
name: 'list',
component: List
}
]
})

4、配置路由器
// 导入当前项目中创建的路由器对象
import router from './router'
new Vue({
render: h => h(App),
// 在Vue的实例上,配置一个路由器对象
router
}).$mount('#app')

5、使用路由
(1)路由组件跳转
router-link是路由链接组件,用于跳转路由。通过传入 to 属性指定链接, 即要显示的内容。router-link默认会被渲染成一个 <a> 标签。
router-view是路由视图组件,用于呈现路由页面。

<router-link to="/home">首页</router-link>
<router-link to="/list">列表</router-link>
<router-view></router-view>
(2)编程式路由跳转
编程式路由跳转,可以在跳转之前,做各种验证,比如判断权限等等。
route返回的是当前路由信息。router是当前vue实例里面的路由器对象。
push方法:用于跳转路由,在浏览器的历史记录中,添加一个路由信息。需要注意,不能反复push同一个路由地址。
replace方法:也是用于跳转路由。它用当前地址替换历史记录里面的最近一条地址。

<button @click="gotoHome">首页</button> 
<button @click="gotoList">列表</button>
<router-view></router-view>
methods: {
gotoHome() {
if (this.route.path !== "/home") { this.router.push("/home");
}
},
gotoList() {
if (this.route.path !== "/list") { this.router.push("/list");
}
}
}

二、swiper插件

Swiper是纯javascript打造的滑动特效插件,面向手机、平板电脑等移动终端。Swiper能实现触屏焦点图、触屏Tab切换、触屏轮播图切换等常用效果。

1、安装

npm install swiper@5 vue-awesome-swiper@4

2、导入

(1)全局导入

在入口文件main.js中全局导入。

导入swiper
import VueAwesomeSwiper from 'vue-awesome-swiper'
导入swiper的样式
import 'swiper/css/swiper.css'
因为swiper是插件,所以要use
Vue.use(VueAwesomeSwiper)

(2)局部导入

在需要使用swiper插件的页面组件中引入。
局部导入的优势:只有在页面组件使用swiper插件时,才会引入插件,起到一个懒加载作用;全局导入不管是否使用,都会引入。局部更有利于性能优化,全局更方便开发。

导入swiper的组件
import { Swiper, SwiperSlide } from 'vue-awesome-swiper'
导入swiper的样式
import 'swiper/css/swiper.css'
export default {
注册组件
components: {
Swiper,
SwiperSlide
}
}

3、使用

<div class="box">

<swiper :options="swiperOptions">

<swiper-slide>
<img src="http://p1.music.126.net/Y6gItVxUvkbvI2cC8KVZYA==/109951166461233203.jpg?imageView&quality=89">
</swiper-slide>
<swiper-slide>
<img src="http://p1.music.126.net/ypjEcAl-BXKqb2UWdau-Tw==/109951166463199078.jpg?imageView&quality=89">
</swiper-slide>
<swiper-slide>
<img src="http://p1.music.126.net/_7zX4BjboCYo4KYRvpayDg==/109951166461246383.jpg?imageView&quality=89">
</swiper-slide>
<swiper-slide>
<img src="http://p1.music.126.net/3Vwphalm49ewNV-lIJUBNA==/109951166461279853.jpg?imageView&quality=89">
</swiper-slide>

<div class="swiper-pagination" slot="pagination"></div>

<div class="swiper-button-prev" slot="button-prev"></div>

<div class="swiper-button-next" slot="button-next"></div>
</swiper>
</div>

data() {
return {
// 定义swiper的配置选项
swiperOptions: {
// 指定分页器
pagination: {
// 指定分页器的容器
el: ".swiper-pagination",
// 点击分页器的指示点分页器会控制Swiper切换
clickable:true
},
// 配置自动播放
// autoplay:true
autoplay:{
//自动播放
autoplay:true,
// 设置间隔时间
delay:3000,
// 用户操作swiper之后,是否禁止autoplay
disableOnInteraction:false
},
// 配置衔接滑动
loop:true,
// 箭头
navigation:{
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev',
},
// slide的切换效果
effect:'cube',
},
}
},
};

三、Echarts使用

Echarts是一个基于 JavaScript 的开源可视化图表库。

1、安装

npm install echarts --save

2、导入

import * as echarts from 'echarts';

关闭eslint语法检查

"eslintConfig": {
"rules": {
"no-unused-vars": "off"
}
}

3、准备容器

<div class="charts">
<h3>使用ECharts</h3>
<div id="main"></div>
</div>

4、选择示例图

在官网选择[示例图]并下载示例。

5、引入 ECharts

基于准备好的dom初始化echarts实例,绘制图表。因为该项目是基于vue,所以需要在mounted生命周期中进行这一步(获取dom,需要在页面挂载完成后进行)。

(1)柱状图实例

通过axios获取后台数据。(注意:axios需要先安装,再导入)

导入axios
import axios from "axios";
export default {
name: "Test",
data() {
return {
定义一份数据
list: [],
};
},
methods: {
加载数据的方法
async getList() {
向后台发送请求,获取一份数据
let {data} = await axios.get("data/data2.json");
this.list = data
this.showdata()
},
渲染数据的方法
showdata() {
基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById("main"));
绘制图表
myChart.setOption({
title: {
text: "产品销售信息",
// 副标题
subtext: "2021-12-08",
},
图例组件
legend: {},
tooltip: {},
// X轴信息
xAxis: {
// 产品名称数据作为X轴信息展示
data: this.list.map((r) => r.title),
},
Y轴信息
yAxis: {},
系列
series: [
{
name: "销量",
type: "bar",
data: this.list.map((r) => r.xl),
},
{
name: "库存",
type: "bar",
data: this.list.map((r) => r.kc),
},
],
});
},
},
/页面挂载完成
mounted() {
this.getList();
},
};

数据:

[
{
"title": "衬衫",
"xl": 5,
"kc": 9
},
{
"title": "羊毛衫",
"xl": 20,
"kc": 19
},
{
"title": "雪纺衫",
"xl": 36,
"kc": 55
},
{
"title": "裤子",
"xl": 10,
"kc": 2
},
{
"title": "高跟鞋",
"xl": 10,
"kc": 5
},
{
"title": "袜子",
"xl": 20,
"kc": 35
}
]

效果:

image

(2)饼图实例

export default {
name: "News",
data() {
return {
list: [
{ value: 40, name: "游泳" },
{ value: 38, name: "跳水" },
{ value: 32, name: "短跑" },
{ value: 30, name: "长跑" },
{ value: 28, name: "扔铅球" },
{ value: 26, name: "举重" },
{ value: 22, name: "划船" },
{ value: 18, name: "打排球" },
],
};
},
mounted() {
基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById("container"));
绘制图表
myChart.setOption({
标题
title: {
text: "运动项目",
},
提示框组件
tooltip: {
触发类型:axis,item,none
trigger: "item",
},
图例组件
legend: {
图例组件离容器上侧的距离
top: "bottom",
},
工具栏
toolbox: {
show: true,
feature: {
mark: { show: true },
dataView: { show: true, readOnly: false },
restore: { show: true },
saveAsImage: { show: true },
},
},
series: [
{
系列名称
name: "series",
类型,饼图
type: "pie",
radius: [50, 250],
饼图的中心(圆心)坐标,数组的第一项是横坐标,第二项是纵坐标。
center: ["50%", "50%"],
是否展示成南丁格尔图,通过半径区分数据大小。可选择两种模式:
'radius' 扇区圆心角展现数据的百分比,半径展现数据的大小。
'area' 所有扇区圆心角相同,仅通过半径展现数据大小。
roseType: "area",
图形样式
itemStyle: {
用于指定饼图扇形区块的内外圆角半径
borderRadius: 8,
},
data: [
name:数据项名称
value:数据值
...this.list.map((r) => {
return {
value: r.value,
name: r.name,
};
}),
],
},
],
});
},
};

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容