第一步,给vue页面添加锚点
.orange{ color: #f97910; }
<template> <div class="productDetail" ref="content"> <div class="tabbar"> <div @click.prevent="tabclick(index)" v-for="(item,index) in productTile" :key="index" :class="{orange:index==current}">{{item}}</div> </div> <div id="0">...</div> <div id="1">...</div> <div id="2">...</div> </div> <template>
tabclick(index){ this.current=index; let anchorElement = document.getElementById(index); if(anchorElement) { anchorElement.scrollIntoView(); } },
第二步:给class为productDetail的<div>部分加height:100%;overflow-y: scroll;
.productDetail { width: 100%; height: 100%; display: flex; flex-direction: column; overflow-y: scroll; }
第三步,添加监听事件
document.getElementsByClassName('productDetail')[0]; vue中同理于:this.$refs.content methods:{ handleScroll(el) { this.scrollTop = this.$refs.content.scrollTop; if (this.scrollTop >= 460) { this.current = 2 } else if (this.scrollTop < 460 && this.scrollTop >= 360) { this.current = 1 } else { this.current = 0 } }, }, mounted() { //scoll滚动事件监听 var pro_detail_page = document.getElementsByClassName('productDetail')[0]; pro_detail_page.addEventListener('scroll', this.handleScroll); },
注:给最外层div添加height:100%后,mint-ui的轮播图就会展示不出来。我们可以修改mint-ui的默认overflow属性,改为:overflow:visible
补充知识:使用Vuepress自动生成markdown的目录时,一旦标题有数字时便无法跳转的问题解决
问题描述
最近在用vuepress写网页文档的时候发现了一个问题,就是我用markdown书写的标题中如果有类似 1.2 XXX 的标题时,当使用官方文档给出的:
[[toc]]
自动生成目录时,最终生成的网页,含有数字的标题是无法跳转到相应位置的。
问题分析
查看官方开发文档后发现,这跟vuepress的默认配置有关,从如图1所示markdown.slugify函数可以看到,我们需要修改其配置。
markdown.slugify函数
图1 markdown.slugify函数
点击图中的source,跳转到GitHub的工程页面,可以看到如下的代码段:
// string.js slugify drops non ascii chars so we have to // use a custom implementation here // @ts-ignore import { remove as removeDiacritics } from 'diacritics' // eslint-disable-next-line no-control-regex const rControl = /[\u0000-\u001f]/g const rSpecial = /[\s~`!@#$%^&*()\-_+=[\]{}|\\;:"'<>,.?/]+/g export = function slugify (str: string): string { return removeDiacritics(str) // Remove control characters .replace(rControl, '') // Replace special characters .replace(rSpecial, '-') // Remove continous separators .replace(/\-{2,}/g, '-') // Remove prefixing and trailing separtors .replace(/^\-+|\-+$/g, '') // ensure it doesn't start with a number (#121) .replace(/^(\d)/, '_$1') // lowercase .toLowerCase() }
看到了其中有一句ensure it doesn't start with a number (#121),可以知道这就是问题所在:
// ensure it doesn't start with a number (#121)
.replace(/^(\d)/, '_$1')
我们的标题数字被这句代码替换掉了,导致最终的链接根本没有指向标题,故无法跳转。
问题解决
根据GitHub页面上的配置路径,找到自己安装的vuepress模块的配置路径,我的路径是:
D:\my_program\nodejs\node_global\node_modules\vuepress\node_modules\@vuepress\shared-utils\lib\slugify.js
打开 slugify.js 文件,并将上述的代码段注释掉,问题即可解决。
以上这篇vue添加锚点,实现滚动页面时锚点添加相应的class操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]