亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

vue添加錨點,實現滾動頁面時錨點添加相應的class操作

瀏覽:75日期:2023-10-15 10:32:57

第一步,給vue頁面添加錨點

.orange{ color: #f97910;}

<template> <div 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.contentmethods:{ 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函數

vue添加錨點,實現滾動頁面時錨點添加相應的class操作

圖1 markdown.slugify函數

點擊圖中的source,跳轉到GitHub的工程頁面,可以看到如下的代碼段:

// string.js slugify drops non ascii chars so we have to// use a custom implementation here// @ts-ignoreimport { remove as removeDiacritics } from ’diacritics’ // eslint-disable-next-line no-control-regexconst rControl = /[u0000-u001f]/gconst 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_programnodejsnode_globalnode_modulesvuepressnode_modules@vuepressshared-utilslibslugify.js

打開 slugify.js 文件,并將上述的代碼段注釋掉,問題即可解決。

以上這篇vue添加錨點,實現滾動頁面時錨點添加相應的class操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: vue
主站蜘蛛池模板: 免费在线亚洲视频 | 国产三级精品播放 | 香蕉久久精品 | 亚洲人的天堂男人爽爽爽 | 无毒在线| 国产性较精品视频免费 | 国产欧美日韩精品a在线观看 | 免费高清不卡毛片在线看 | 亚洲免费大全 | 中文字幕三区 | 欧美韩国日本在线 | 理论片亚洲| 91久久国产露脸精品免费 | 美美女高清毛片视频免费观看 | 特黄毛片 | 久久性妇女精品免费 | 香蕉视频老司机 | 精品午夜国产在线观看不卡 | 一国产一级淫片a免费播放口 | 亚洲精品成人一区二区 | 精品国产香蕉在线播出 | 国产亚洲精品久久久久91网站 | 中文字幕精品视频在线 | 欧美一线高本道高清在线 | 日本亚洲欧美高清专区vr专区 | 免费真实播放国产乱子伦 | 国产成人综合自拍 | 91久久香蕉青青草原娱乐 | 欧美在线精品一区二区三区 | 精品视频h| 永久免费不卡在线观看黄网站 | 欧美亚洲激情视频 | 欧美高清一级毛片免费视 | 亚洲男人天堂2017 | 国产一级高清 | 操你.com| 日韩一区二区久久久久久 | 美女视频黄a视频美女大全 美女视频黄a视频免费全程 | 成人性生免费视频 | 色偷偷亚洲精品一区 | 国产三级精品在线观看 |