国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - Vue 虛擬列表的實戰(zhàn)示例

Vue 虛擬列表的實戰(zhàn)示例

2022-02-19 17:42掘金安東尼 vue.js

這篇文章主要介紹了Vue 虛擬列表的實現(xiàn)示例,幫助大家更好的理解和學習使用vue,感興趣的朋友可以了解下

序言

現(xiàn)如今,我們總是在無止境的刷。刷微博、刷抖音、刷沸點......一次次絲滑下拉體驗的背后卻是前端攻城獅的用心。

本篇討論基于 Vue.js 的列表無限下拉實踐。

我們的目標就是:讓列表下拉縱享絲滑,而不是像以往的下拉就 loading 等待的體驗。

設計

咱還是用 Vue CLI 來快速構建項目。

這是主頁面:

// EndlessList.vue

<template>
 <div class="endless-scrolling-list">
  <!-- 搜索框 -->
  <div class="search-box">
   <input type="text" v-model="searchQuery"/>
  </div>
  <p class="center" v-if="results.length == 0 && !loading">
   Start typing to search something.
  </p>
  <!-- 虛擬列表 -->
  <virtual-list
   :data-key=""pageid""
   :data-sources="results"
   :data-component="itemComponent"
   :page-mode="true"
   />
  <!-- loading -->
  <loader v-if="loading" />
 </div>
</template>

其中核心當然是virtual-list組件啦~

這里的虛擬列表,我們用到一個三方庫 Vue Virtual Scroll List,它在 Github 上又 2.5k+ 的 stars。類比于 react 的 react-virtualized 庫。

Vue 虛擬列表的實戰(zhàn)示例

大量的 DOM 元素會使得我們的網(wǎng)頁非常“重”。當 DOM 元素超過 1500 至 2000 個的時候,頁面就開始又延遲,尤其是在小型的、性能差的設備上尤為明顯。

想象一下,有一個無線滾動的頁面,你不斷的下拉,它實際上可能形成了上萬個 DOM 元素,每個元素還包含子節(jié)點,這樣將消耗巨大的性能。

Virtual scrollers 正是來解決這個問題的。

如上圖,已經(jīng)表示的很清楚了。列表分為可見區(qū)域和緩沖區(qū)域,超出這個范圍的列表 DOM 都將被刪除。

好啦,準備工作已就緒,Let`s get it!

實現(xiàn)

// imports.js(EndlessList.vue)

import axios from "axios";
import lodash from "lodash";
import VirtualList from "vue-virtual-scroll-list";
import SearchResult from "./SearchResult";
import Loader from "./Loader";
export default {
 name: "EndlessList",
 components: {
  VirtualList,
  Loader
 },
 data() {
  return {
   searchQuery: "",
   currentPage: 0,
   results: [],
   itemComponent: SearchResult,
   loading: false
  }
 },
};

我們引入第三方庫 axios 和 loadsh,以便后續(xù)使用。

其中,itemComponent 是 virtual-list 的屬性,為此我們需要新建一個 SearchResult 子組件,作為搜索結果單元。

代碼如下:

// SearchResult.vue

<template>
 <div class="list-item">
  <h3>
   {{ source.title }}
  </h3>
  <div v-html="source.snippet"></div>
 </div>
</template>

<script>
export default {
 props: {
  index: {
   // index of current item
   type: Number,
  },
  source: {
   type: Object,
   default() {
    return {};
   },
  },
 },
};
</script>

<style scoped>
.list-item {
 padding: 0 10px 20px 10px;
}
.list-item h3 {
 margin: 0;
 padding-bottom: 10px;
}
</style>

我們可以通過搜索標題或描述來得到結果,請求數(shù)據(jù)來源于維基百科。

search(query, page) {
 // We prepare the data that the Wikipedia API expects.
 const data = {
  action: "query",
  format: "json",
  list: "search",
  continue: "-||",
  utf8: 1,
  srsearch: query,
  sroffset: page * 10,
  origin: "*",
 };
 // And then we convert these params TO GET params in the format
 // action=query&format=json ...
 const params = Object.keys(data)
  .map(function(k) {
   return data[k] == ""
    ? ""
    : encodeURIComponent(k) + "=" + encodeURIComponent(data[k]);
  })
  .join("&");
 // We prepare the url with the params string
 const searchUrl = `https://en.wikipedia.org/w/api.php?${params}`;
 // we set loading to true so that we can display the loader 
 this.loading = true;
 // Then we execute the request and concatenate the results
 axios.get(searchUrl).then((response) => {
  this.results = this.results.concat(response.data.query.search);
  // And of course set loading to false to hide the loader.
  this.loading = false;
 });
}

搜索的方法已經(jīng)寫好,接著就是調(diào)用。

  1. 當用戶鍵入內(nèi)容的搜索時候會調(diào)用。
  2. 當下拉的時候會調(diào)用。

// EndlessList.vue

<script>
export default {
 // data() and methods skipped for brevity
 watch: {
  searchQuery: {
   immediate: true,
   handler: lodash.debounce(function (newVal) {
    if (newVal == "") {
     return;
    }
    this.results = [];
    this.currentPage = 0;
    this.search(newVal, this.currentPage);
    this.search(newVal, this.currentPage + 1);
    this.currentPage = 2;
   }, 200),
  },
 },
 mounted() {
  const vm = this;
  window.onscroll = lodash.debounce(function () {
   var distanceFromBottom =
    document.body.scrollHeight - window.innerHeight - window.scrollY;
   if (distanceFromBottom < 400 && vm.searchQuery !== "") {
    vm.search(vm.searchQuery, vm.currentPage);
    vm.currentPage++;
   }
  }, 100, {leading: true});
 },
}
</script>

顯而易見,當 searchQuery 變化的時候,我們會得到新的搜索結果。當然,這里的輸入框也用到了防抖函數(shù)。

另一個需要注意的是,我們第一次搜索加載了兩頁的結果,用戶就會有一定的滾動空間,這樣就可以保持順暢的感覺。

我們在滾動的事件中也加了防抖函數(shù)。這里設一個疑問:為什么要在 window.onscroll 事件下設置 leading 為 true ?

然后我們運行程序看效果:

Vue 虛擬列表的實戰(zhàn)示例

npm run dev

Vue 虛擬列表的實戰(zhàn)示例

如何?只要你不是瘋狂下拉,基本上感受不到 loading 的過程~

小結

用戶不會希望每下拉十條結果就要等待新的十條結果加載出來!所以我們需要有緩沖區(qū),還未下拉到底的時候就預判它到底然后提前加載。這便是絲滑體驗的內(nèi)核。

當然不在視圖區(qū)和緩沖區(qū)的 DOM 都將被刪除,這也是頁面不形成大量 DOM 元素的精髓。

這樣動態(tài)的處理列表的確是編程人員的一種智慧和用心。

你可以把 項目  克隆到本地再體會一下。以上便是本次分享~

以上就是Vue 虛擬列表的實現(xiàn)示例的詳細內(nèi)容,更多關于Vue 虛擬列表的資料請關注服務器之家其它相關文章!

原文鏈接:https://juejin.cn/post/6937939870018961439

延伸 · 閱讀

精彩推薦
  • vue.jsVue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn)

    Vue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn)

    這篇文章主要介紹了Vue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優(yōu)小U9632022-02-21
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
  • vue.js用vite搭建vue3應用的實現(xiàn)方法

    用vite搭建vue3應用的實現(xiàn)方法

    這篇文章主要介紹了用vite搭建vue3應用的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue2.x-使用防抖以及節(jié)流的示例

    Vue2.x-使用防抖以及節(jié)流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節(jié)流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
  • vue.jsVue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    Vue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    最近做了一個手機端系統(tǒng),其中遇到了父頁面需要攜帶參數(shù)跳轉(zhuǎn)至子頁面的問題,現(xiàn)已解決,下面分享一下實現(xiàn)過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
主站蜘蛛池模板: 欧美性久久 | 久久xxx | 午夜影院在线播放 | 91中文在线| 日韩精品一级毛片 | 国产乱码精品一区二区三区中文 | 久草一区 | 91免费国产在线 | av毛片免费看 | 一级黄色片欧美 | 中文字幕 日韩有码 | 91色在线观看 | 极品久久| 日本a v在线播放 | 草草精品视频 | 久久99精品国产99久久6尤 | 在线成人亚洲 | 成人免费小视频 | 成年人xxxx | 在线播放国产精品 | 日本www视频| 日韩av中文字幕在线播放 | 日韩欧美国产一区二区三区 | 日操干| 欧美精品在线播放 | 污污视频免费网站 | 在线观看一区二区三区视频 | 日本中文字幕在线播放 | 3d动漫精品一区二区三区 | 亚洲综合在线视频 | 精品国产精品三级精品av网址 | 羞羞动漫网 | 亚洲国产精品视频一区 | 欧美黄色精品 | 中文字幕,久热精品,视频在线 | 国产精品国色综合久久 | 中文字幕一区二区三区在线观看 | 日日日操 | 天天躁人人躁人人躁狂躁 | 欧美日韩在线一区 | 国产精品99在线观看 |