亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用Vue3+Vant組件實現(xiàn)App搜索歷史記錄功能(示例代碼)

 更新時間:2021年06月09日 16:55:18   作者:L_不覺曉曉  
最近接了個項目需要開發(fā)一個app項目,由于是第一次接觸這種app開發(fā),經(jīng)過一番思考,決定使用Vue3+Vant前端組件的模式進行開發(fā),下面把問題分析及實現(xiàn)代碼分享給大家,需要的朋友參考下吧

最近在開發(fā)一款新的app項目,我自己也是第一次接觸app開發(fā),經(jīng)過團隊的一段時間研究調(diào)查,決定使用Vue3+Vant前端組件的模式進行開發(fā),vue2開發(fā)我們已經(jīng)用過幾個項目了,所以決定這一次嘗試使用Vue3來進行前段開發(fā)。
我剛開始負責(zé)搜索功能的開發(fā),有歷史搜索記錄的需求,一開始我認為這是記錄的存儲信息也會放在一個數(shù)據(jù)庫表里面,但經(jīng)過一番調(diào)查,發(fā)現(xiàn)并不是這樣,而是要存儲在本地。但是網(wǎng)上的方法也并沒有完全解決問題,經(jīng)過一番嘗試,終于給搞好了,話不多說,直接上效果圖。
初始化不顯示歷史搜索記錄

初始化bu不顯示歷史搜索記錄

回車搜索進入詳情頁面

回車搜索進入詳情頁面

歷史記錄頁面

回車搜索將歷史記錄信息加載出來

清除歷史記錄

清除歷史記錄

首先創(chuàng)建一個js文件
這個js文件主要包括了增加歷史記錄信息,刪除所有歷史記錄信息的功能

export default {

  // 添加搜索首頁歷史查詢記錄
  addSearchHistory(state, payload) {
    // list中包含該記錄的時,刪除
    const index = state.searchHistoryList.indexOf(payload);
    if (index > -1) {
      state.searchHistoryList.splice(index, 1);
    }
    state.searchHistoryList.unshift(payload);
    // 歷史記錄中最大記20個記錄
    const count = state.searchHistoryList.length;
    state.searchHistoryList.splice(20, count);
  },

  // 清除搜索首頁歷史查詢記錄
  clearSearchHistory(state) {
    state.searchHistoryList = [];
  },
};

Vue代碼塊

<template>
  <!-- 搜索框 -->
  <search-bar
    @searchClick="searchClick"
    :placeholderValue="state.placeholderValue"
    :searchVal="state.searchVal">
  </search-bar>
  <div class="search">

    <!-- 搜索歷史 -->
    <div class="history" v-if="state.isShowHistory">
      <span class="proHot">搜索歷史</span>
      <span class="delHotSearch" @click="delHostClick">清除歷史</span>

      <!-- 存放歷史記錄信息 -->
      <div class="searchBtn-div">
        <span v-for="(item, index) in state.historyList" :key="index" class="searchValBtn" >
        <van-button
          round
          size="small"
          @click="searchValClick(item)"
          >{{ item }}
        </van-button>
      </span>
      </div>
    </div>
  </div>
</template>

<script>
import {
  onMounted,
  reactive,
  getCurrentInstance,
} from 'vue';
import { Toast, Dialog } from 'vant';
import searchBar from '@/components/SearchBar.vue';
import { useRouter } from 'vue-router';
import { useStore } from 'vuex';

export default {

  components: {
    searchBar,
  },

  setup() {
    const router = useRouter();
    const store = useStore();
    const { proxy } = getCurrentInstance();
    const state = reactive({
      isShowHistory: '', // 是否顯示歷史記錄
      searchVal: '', // 搜索關(guān)鍵字
      placeholderValue: '搜索產(chǎn)品/資訊/標準/成分/企業(yè)',
      historyList: [], // 歷史搜索數(shù)據(jù)
    });


    // 回車搜索
    const searchClick = (val) => {
      store.commit('addSearchHistory', val);
      // router.push({ path: '/search-detail', query: { searchVal: val } });
    };

    // 清除歷史記錄
    const delHostClick = async () => {
      Dialog.confirm({
        message: '確定要刪除歷史搜索嗎?',
      }).then(() => {
        store.commit('clearSearchHistory', store);
        state.isShowHistory = false;
        Toast({
          message: '刪除成功',
          position: 'bottom',
        });
      });
    };
	
	// 初始化獲取歷史搜索記錄信息
    onMounted(async () => {
      // 獲取歷史搜索信息
      state.historyList = store.state.searchHistoryList;
      // 判斷初始化是否顯示歷史搜索
      if (state.historyList.length > 0) {
        state.isShowHistory = true;
      } else {
        state.isShowHistory = false;
      }
    });

    return {
      state,
      searchClick,
      delHostClick,
    };
  },
};
</script>

<style lang="less" scoped>
</style>

Vue代碼直接粘貼復(fù)制的話可能沒法直接用,因為這里面有好多業(yè)務(wù)代碼已經(jīng)刪除,留下的主要是歷史搜索記錄的代碼。主要有三個重點:

引入useStore

import { useStore } from 'vuex';

const store = useStore();

初始化檢索歷史搜索記錄

// 初始化獲取歷史搜索記錄信息
	// 每次加載這和頁面都會首先調(diào)用這個方法,來取最新的信息
    onMounted(async () => {
      // 獲取歷史搜索信息
      state.historyList = store.state.searchHistoryList;
      // 判斷初始化是否顯示歷史搜索
      if (state.historyList.length > 0) {
        state.isShowHistory = true;
      } else {
        state.isShowHistory = false;
      }
    })

搜索框觸發(fā)搜索事件將搜索信息存放在Store中

// 子組件發(fā)射一個事件,父組件調(diào)用
    const searchClick = (val) => {
    	// 將搜索值放入歷史記錄中	
      store.commit('addSearchHistory', val);
      // 路由跳轉(zhuǎn)可以忽略
      // router.push({ path: '/search-detail', query: { searchVal: val } });
    };

清空歷史記錄

// 清除歷史記錄
    const delHostClick = async () => {
      Dialog.confirm({
        message: '確定要刪除歷史搜索嗎?',
      }).then(() => {
      	// 清空歷史記錄信息
        store.commit('clearSearchHistory', store);
        state.isShowHistory = false;
        Toast({
          message: '刪除成功',
          position: 'bottom',
        });
      });
    };

以上就是使用Vue3+Vant組件實現(xiàn)App搜索歷史記錄功能的詳細內(nèi)容,更多關(guān)于vue 搜索歷史記錄的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 關(guān)于Vue的異步組件

    關(guān)于Vue的異步組件

    在大型項目中,我們可能需要拆分應(yīng)用為更小的塊,并僅在需要時再從服務(wù)器加載相關(guān)組件。Vue 提供了defineAsyncComponent 方法來實現(xiàn)此功能,需要的朋友可以參考下
    2023-04-04
  • 在vue中添加Echarts圖表的基本使用教程

    在vue中添加Echarts圖表的基本使用教程

    雖然老早就看過很多echarts的例子, 但自己接觸的項目中一直都沒有真正用到過,直到最近才開始真正使用,下面這篇文章主要給大家介紹了關(guān)于在vue中添加Echarts圖表的基本使用教程,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-11-11
  • vue實現(xiàn)登錄攔截

    vue實現(xiàn)登錄攔截

    這篇文章主要介紹了vue實現(xiàn)登錄攔截,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 前端vue-cropperjs實現(xiàn)圖片裁剪方案

    前端vue-cropperjs實現(xiàn)圖片裁剪方案

    這篇文章主要為大家介紹了前端vue-cropperjs實現(xiàn)圖片裁剪方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • vue-cli中的babel配置文件.babelrc實例詳解

    vue-cli中的babel配置文件.babelrc實例詳解

    Babel是一個廣泛使用的轉(zhuǎn)碼器,可以將ES6代碼轉(zhuǎn)為ES5代碼,從而在現(xiàn)有環(huán)境執(zhí)行。本文介紹vue-cli腳手架工具根目錄的babelrc配置文件,感興趣的朋友一起看看吧
    2018-02-02
  • Vue.js分頁組件實現(xiàn):diVuePagination的使用詳解

    Vue.js分頁組件實現(xiàn):diVuePagination的使用詳解

    這篇文章主要介紹了Vue.js分頁組件實現(xiàn):diVuePagination的使用詳解,需要的朋友可以參考下
    2018-01-01
  • vue實現(xiàn)輪播圖的多種方式

    vue實現(xiàn)輪播圖的多種方式

    這篇文章給大家介紹了vue實現(xiàn)輪播圖的多種方式,文中給出了四種實現(xiàn)方式,并通過代碼示例給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,感興趣的朋友可以參考下
    2024-02-02
  • Vue3?Transition組件給頁面切換并加上動畫效果

    Vue3?Transition組件給頁面切換并加上動畫效果

    這篇文章主要給大家介紹了關(guān)于Vue3?Transition組件給頁面切換并加上動畫效果的相關(guān)資料,vue的過渡動畫主要是transition標簽的使用,配合css動畫實現(xiàn)的,需要的朋友可以參考下
    2023-06-06
  • vue打包時不刪除dist里的原有文件配置方法

    vue打包時不刪除dist里的原有文件配置方法

    這篇文章主要為大家介紹了vue打包時不刪除dist里的原有文件配置方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Vue項目引進ElementUI組件的方法

    Vue項目引進ElementUI組件的方法

    這篇文章主要介紹了Vue項目引進ElementUI組件的方法,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2018-11-11

最新評論