search
HomeWeb Front-endJS TutorialVue implements paging without refreshing

Vue implements paging without refreshing

Apr 27, 2018 pm 01:36 PM
Paginationrefreshaccomplish

This time I will bring you Vue to implement non-refresh paging. What are the precautions for Vue to implement non-refresh paging. The following is a practical case, let's take a look.

I have always wanted to try to implement a paging device by myself, but I kept procrastinating. I finished it today, and I probably finished it in the same way as NetEase Cloud Music. This small example is very simple. Through this small example, you can learn the use of Vue calculated properties and understand the situations that need to be distinguished when writing a pager. This article will slowly implement this small example from scratch. I believe you will learn it, and maybe you will have better ideas and ideas after reading my ideas!

The effect achieved is like this:

##1. First, simple layout

<template>
 <p>
  </p>
<ul>
   <li><span></span></li>
   <li>
    <span>{{item}}</span>
   </li>
   <li><span></span></li>
  </ul>
 </template>

<script> export default { computed: { pages() { return 10; } } }; </script> The effect is as follows:

There are two places to mention:

    The first and last two icons are used font awesome's cdn
  1. The data rendered using v-for uses pages in the calculated attribute. A data of 11 is temporarily written, so 11 tags are rendered
2. Clarify your thoughts, which is the most important in this example

The example in this article refers to the paging method in NetEase Cloud Music. NetEase’s picture:

It has several characteristics:

    The homepage and last page always have
  1. At most there are 11
  2. tab pages

    , including two..., but they cannot be clicked, so I also set the page number in the example to 11

  3. When the current page changes, the form of the page number will also change. There are three situations in total. The following will detail the three situations of
  4. Paging:

First type: When the current page number is less than or equal to 5

As shown in the figure:

In this case, the first and last pages are retained, and the second to last page is retained. The page number is..., the page number is counted from the beginning to the end

The second situation: When the current page number is at the last 5

As shown:

The first and last pages are still retained, the second page number is..., the page number is counted from the end to the front

The third situation: when the page is in the middle position

As shown in the picture:

The first and last pages are retained, the second page number and the penultimate page number are both..., and the page moves from the current page number position to both Side calculation

3. Use code to realize the above three situations

From the above idea, how the page number is presented is determined by the position of the current page number, so We need to set a

current

Page:1 in the data, and the pages used to render the page number in the calculated attribute are controlled by currentPage, and a total number of pages totalPages:50 is also required. Write the first situation first:

<script>
export default {
 data() {
  return {
   currentPage: 1,
   totalPages: 50
  }
 },
 computed: {
  pages() {
   const c = this.currentPage
   const t = this.totalPages
   if (c <= 5) {
    return [1, 2, 3, 4, 5, 6, 7, 8, 9, &#39;...&#39;, t]
   }
  }
 }
};
</script>

The effect is as follows:

##Write the second situation and add an if:

<script>
export default {
 data() {
  return {
   currentPage: 47,
   totalPages: 50
  }
 },
 computed: {
  pages() {
   const c = this.currentPage
   const t = this.totalPages
   if (c <= 5) {
    return [1, 2, 3, 4, 5, 6, 7, 8, 9, &#39;...&#39;, t]
   } else if (c >= t - 4) {
    return [1, &#39;...&#39;, t-8, t-7, t-6, t-5, t-4, t-3, t-2, t-1, t]
   }
  }
 }
};
</script>
Set the value of currentPage to >= 46, the effect is as follows:

Add the third situation:

computed: {
  pages() {
   const c = this.currentPage
   const t = this.totalPages
   if (c = t - 4) {
    return [1, '...', t-8, t-7, t-6, t-5, t-4, t-3, t-2, t-1, t] //第二种情况
   } else {
    return [1, '...', c-3, c-2, c-1, c, c+1, c+2, c+3, '...', t] //第三种情况
   }
  }
 }
That's basically it. You can already see the changes in the pager by changing the value of currentPage.

接下来实现点击相应的页码来改变currentPage的值,只要写一个点击事件再写一个函数就好了。


  • ... methods: {   select(item) {     this.currentPage = item   } } ... actived: {   border-color: #2d8cf0;   background-color: #2d8cf0;   color: #fff; }

    效果如下:

    为了让当前页码更清楚,再在页面上加上当前多少页

    <p>当前第{{currentPage}}页</p>

    效果如下:

    发现了一bug,就是我们每次点击的时候,都是将item的具体内容传递过去改变currentIPage的,但是当我们点的 ... 的时候就把它也传递过去了,但是它不是我们要的页码的数据,在计算的时候就出错了,所以我们需要做一点处理。同时,还有再点击当前页码的时候也不必再执行select函数了。

    简单改写一下select函数:

    select(n) {
      if (n === this.currentPage) return 
      if (typeof n === 'string') return 
      this.currentPage = n
    }

    这样就正常了。

    再把两侧icon向前一页和向后一页的功能加上,因为一个是加1一个是减1,所以写一个函数传递不同的参数就行了。

    
    
  • ...
  • ... prevOrNext(n) {   this.currentPage += n }

    效果如下:

    呃,边界问题,当currentPage为1时就不能再减了,当它为最大时也不能再加了。

    改写一下代码:

    prevOrNext (n) {
     this.currentPage += n
     this.currentPage  this.totalPages
      ? this.currentPage = this.totalPages
      : null
    }

    这下就可以了,如图:

    四、 结语

    写到这里,这个分页器基本功能就写完了,当然,我们还可以继续封装,在每次改变currentPage的时候用this.$emit通知外面实现通信,还可以通过props来向内传递数据,比如传递totalPages等,这些都是可以继续完善的内容。最重要的一点,关于分页器的具体计算方法,我用的是最笨的方法,所以同志们要是知道更好的办法记得留言啊~

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    vue移动端实现下拉刷新步骤详解

    Angular+Font-Awesome步骤详解

    js与typescript中class使用详解

    The above is the detailed content of Vue implements paging without refreshing. For more information, please follow other related articles on the PHP Chinese website!

    Statement
    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
    Behind the Scenes: What Language Powers JavaScript?Behind the Scenes: What Language Powers JavaScript?Apr 28, 2025 am 12:01 AM

    JavaScript runs in browsers and Node.js environments and relies on the JavaScript engine to parse and execute code. 1) Generate abstract syntax tree (AST) in the parsing stage; 2) convert AST into bytecode or machine code in the compilation stage; 3) execute the compiled code in the execution stage.

    The Future of Python and JavaScript: Trends and PredictionsThe Future of Python and JavaScript: Trends and PredictionsApr 27, 2025 am 12:21 AM

    The future trends of Python and JavaScript include: 1. Python will consolidate its position in the fields of scientific computing and AI, 2. JavaScript will promote the development of web technology, 3. Cross-platform development will become a hot topic, and 4. Performance optimization will be the focus. Both will continue to expand application scenarios in their respective fields and make more breakthroughs in performance.

    Python vs. JavaScript: Development Environments and ToolsPython vs. JavaScript: Development Environments and ToolsApr 26, 2025 am 12:09 AM

    Both Python and JavaScript's choices in development environments are important. 1) Python's development environment includes PyCharm, JupyterNotebook and Anaconda, which are suitable for data science and rapid prototyping. 2) The development environment of JavaScript includes Node.js, VSCode and Webpack, which are suitable for front-end and back-end development. Choosing the right tools according to project needs can improve development efficiency and project success rate.

    Is JavaScript Written in C? Examining the EvidenceIs JavaScript Written in C? Examining the EvidenceApr 25, 2025 am 12:15 AM

    Yes, the engine core of JavaScript is written in C. 1) The C language provides efficient performance and underlying control, which is suitable for the development of JavaScript engine. 2) Taking the V8 engine as an example, its core is written in C, combining the efficiency and object-oriented characteristics of C. 3) The working principle of the JavaScript engine includes parsing, compiling and execution, and the C language plays a key role in these processes.

    JavaScript's Role: Making the Web Interactive and DynamicJavaScript's Role: Making the Web Interactive and DynamicApr 24, 2025 am 12:12 AM

    JavaScript is at the heart of modern websites because it enhances the interactivity and dynamicity of web pages. 1) It allows to change content without refreshing the page, 2) manipulate web pages through DOMAPI, 3) support complex interactive effects such as animation and drag-and-drop, 4) optimize performance and best practices to improve user experience.

    C   and JavaScript: The Connection ExplainedC and JavaScript: The Connection ExplainedApr 23, 2025 am 12:07 AM

    C and JavaScript achieve interoperability through WebAssembly. 1) C code is compiled into WebAssembly module and introduced into JavaScript environment to enhance computing power. 2) In game development, C handles physics engines and graphics rendering, and JavaScript is responsible for game logic and user interface.

    From Websites to Apps: The Diverse Applications of JavaScriptFrom Websites to Apps: The Diverse Applications of JavaScriptApr 22, 2025 am 12:02 AM

    JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.

    Python vs. JavaScript: Use Cases and Applications ComparedPython vs. JavaScript: Use Cases and Applications ComparedApr 21, 2025 am 12:01 AM

    Python is more suitable for data science and automation, while JavaScript is more suitable for front-end and full-stack development. 1. Python performs well in data science and machine learning, using libraries such as NumPy and Pandas for data processing and modeling. 2. Python is concise and efficient in automation and scripting. 3. JavaScript is indispensable in front-end development and is used to build dynamic web pages and single-page applications. 4. JavaScript plays a role in back-end development through Node.js and supports full-stack development.

    See all articles

    Hot AI Tools

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Clothoff.io

    Clothoff.io

    AI clothes remover

    Video Face Swap

    Video Face Swap

    Swap faces in any video effortlessly with our completely free AI face swap tool!

    Hot Tools

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    Powerful PHP integrated development environment

    Notepad++7.3.1

    Notepad++7.3.1

    Easy-to-use and free code editor

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

    SublimeText3 Mac version

    SublimeText3 Mac version

    God-level code editing software (SublimeText3)

    SublimeText3 English version

    SublimeText3 English version

    Recommended: Win version, supports code prompts!