Home > Web Front-end > Front-end Q&A > vue implements anchor scrolling

vue implements anchor scrolling

PHPz
Release: 2023-05-24 11:35:37
Original
2081 people have browsed it

Preface

There are many ways to implement page anchor scrolling, but how does Vue implement it? In Vue, we can use Vue Router to implement anchor scrolling. Below, I will show you how to implement anchor scrolling in Vue through a code demonstration.

Step 1: Install Vue Router

Before using Vue Router, you need to install it first. We can install Vue Router through the following command:

npm install vue-router
Copy after login

or

yarn add vue-router
Copy after login

Step 2: Configure Vue Router

After installing Vue Router, you need to configure Vue Router in the code . In Vue, we need to introduce and use Vue Router in the main.js file, as follows:

import Vue from 'vue'
import VueRouter from 'vue-router'
import App from './App.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/',
    name: 'home',
    component: Home
  },
  {
    path: '/about',
    name: 'about',
    component: About
  },
  {
    path: '/contact',
    name: 'contact',
    component: Contact
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

new Vue({
  router,
  render: h => h(App),
}).$mount('#app')
Copy after login

In the above code, we define three routes, namely '/' and '/about' ,'/contact'. Among them, each route corresponds to a component: Home, About, Contact.

Step 3: Define the page anchor point

In Vue, defining the page anchor point requires adding the id attribute to the HTML element, as shown below:

<div id="section1">Section 1</div>
<div id="section2">Section 2</div>
<div id="section3">Section 3</div>
Copy after login

Steps Four: Define anchor jump links

In Vue, we can generate links through the<router-link> component. We need to define a <router-link> component to realize the page anchor jump, as follows:

<router-link to="#section1">Section 1</router-link>
<router-link to="#section2">Section 2</router-link>
<router-link to="#section3">Section 3</router-link>
Copy after login

In the above code, we use the to attribute to define the link address , its value is the anchor id.

Step 5: Implement anchor scrolling

In Vue, we can implement anchor scrolling through hook functions. We need to scroll to the anchor point after each route jump is completed. The hook function can be defined in Vue's routing. The specific code is as follows:

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes,
  // 定义滚动操作,这里的to和from都是路由信息对象
  scrollBehavior (to, from, savedPosition) {
    if (to.hash) {
      // 滚动到指定的锚点
      return { selector: to.hash }
    } else {
      // 没有指定锚点则返回屏幕最上方
      return { x: 0, y: 0 }
    }
  }
})
Copy after login

In the above code, we define the scrolling operation through scrollBehavior. When there is a hash attribute in the routing object, that is, when the routing jumps to the specified anchor point, the scrolling operation will be performed. Otherwise, the scrolling operation will not be performed.

Conclusion

At this point, we have completed the code to implement page anchor scrolling in Vue. Through the powerful functions of Vue Router, we can easily implement anchor scrolling to improve user experience. If you have other implementation methods, please share them with everyone.

The above is the detailed content of vue implements anchor scrolling. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template