vue添加錨點,實現(xiàn)滾動頁面時錨點添加相應(yīng)的class操作
第一步,給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; }
第三步,添加監(jiān)聽事件
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滾動事件監(jiān)聽 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的目錄時,一旦標(biāo)題有數(shù)字時便無法跳轉(zhuǎn)的問題解決
問題描述
最近在用vuepress寫網(wǎng)頁文檔的時候發(fā)現(xiàn)了一個問題,就是我用markdown書寫的標(biāo)題中如果有類似 1.2 XXX 的標(biāo)題時,當(dāng)使用官方文檔給出的:
[[toc]]
自動生成目錄時,最終生成的網(wǎng)頁,含有數(shù)字的標(biāo)題是無法跳轉(zhuǎn)到相應(yīng)位置的。
問題分析
查看官方開發(fā)文檔后發(fā)現(xiàn),這跟vuepress的默認配置有關(guān),從如圖1所示markdown.slugify函數(shù)可以看到,我們需要修改其配置。
markdown.slugify函數(shù)
圖1 markdown.slugify函數(shù)
點擊圖中的source,跳轉(zhuǎn)到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')
我們的標(biāo)題數(shù)字被這句代碼替換掉了,導(dǎo)致最終的鏈接根本沒有指向標(biāo)題,故無法跳轉(zhuǎn)。
問題解決
根據(jù)GitHub頁面上的配置路徑,找到自己安裝的vuepress模塊的配置路徑,我的路徑是:
D:\my_program\nodejs\node_global\node_modules\vuepress\node_modules\@vuepress\shared-utils\lib\slugify.js
打開 slugify.js 文件,并將上述的代碼段注釋掉,問題即可解決。
以上這篇vue添加錨點,實現(xiàn)滾動頁面時錨點添加相應(yīng)的class操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue使用天地圖、openlayers實現(xiàn)多個底圖疊加顯示效果
這篇文章主要介紹了vue使用天地圖、openlayers實現(xiàn)多個底圖疊加顯示,根據(jù)返回的經(jīng)緯度列表通過天地圖、openlayers實現(xiàn)底圖添加,本文通過示例代碼給大家介紹的非常詳細,需要的朋友參考下吧2022-04-04vue-router 基于后端permissions動態(tài)生成導(dǎo)航菜單的示例代碼
本文主要介紹了vue-router 基于后端permissions動態(tài)生成導(dǎo)航菜單的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法
下面小編就為大家分享一篇axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案
ios密碼框輸入密碼光標(biāo)離開之后會提示存儲密碼的彈窗,關(guān)于這樣的問題怎么解決呢,下面給大家分享IOS上微信小程序密碼框光標(biāo)離開提示存儲密碼的完美解決方案,感興趣的朋友一起看看吧2024-07-07如何使用vue-json-viewer插件展示JSON格式數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于如何使用vue-json-viewer插件展示JSON格式數(shù)據(jù)的相關(guān)資料,Vue-json-viewer是一個Vue組件,用于在Vue應(yīng)用中顯示JSON數(shù)據(jù)的可視化工具,需要的朋友可以參考下2023-11-11