<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        小程序實現搜索框

        來源:懂視網 責編:小采 時間:2020-11-27 21:53:53
        文檔

        小程序實現搜索框

        小程序實現搜索框:小程序中搜索框的簡單實現,供大家參考,具體內容如下 搜索框 搜索框無論是在電商網站還是小程序中是很常見的,那么在小程序中是如何實現的呢,我們一起來看看吧(過程遇到很多問題)。 思路 在搜索框中輸入關鍵詞時,應該會向服務器發送請求,因為沒有相關接
        推薦度:
        導讀小程序實現搜索框:小程序中搜索框的簡單實現,供大家參考,具體內容如下 搜索框 搜索框無論是在電商網站還是小程序中是很常見的,那么在小程序中是如何實現的呢,我們一起來看看吧(過程遇到很多問題)。 思路 在搜索框中輸入關鍵詞時,應該會向服務器發送請求,因為沒有相關接

        小程序中搜索框的簡單實現,供大家參考,具體內容如下

        搜索框

        搜索框無論是在電商網站還是小程序中是很常見的,那么在小程序中是如何實現的呢,我們一起來看看吧(過程遇到很多問題)。

        思路

        在搜索框中輸入關鍵詞時,應該會向服務器發送請求,因為沒有相關接口,所以我就模擬數據啦,用文檔中API中的setStorage和getStorage在本地存儲數據和讀取數據,在搜索框中輸入時若能匹配到則顯示,若匹配不到,則顯示“沒有數據”。

        模糊搜索

        search.wxml

        <!--pages/search/search.wxml-->
        <view class='search'>
         <input type='text' 
         placeholder='請輸入您要搜索的內容'
         bindinput='input' 
         bindconfirm='confirm'/>
         <icon type='search' class='icons'></icon>
         <view wx:for="{{list}}" wx:key='' class='lists'>
         <text wx:if="{{item.show}}">{{item.name}}</text>
         </view>
        </view>

        search.wxss

        /* pages/search/search.wxss */
        .search{
         position: relative;
        }
        .search input{
         border:1px solid #ccc;
         border-radius: 6px;
         height: 30px;
        }
        .icons{
         position: absolute;
         right: 20px;
         top:5px;
        }
        .lists{
         text-align: center;
         margin-top: 20px;
         color: rgb(230, 124, 25);
        }

        search.js

        // pages/search/search.js
        Page({
        
         /**
         * 頁面的初始數據
         */
         data: {
         list:[] 
         },
         //鍵盤輸入時實時調用搜索方法
         input(e){
         // console.log(e)
         this.search(e.detail.value)
         },
         //點擊完成按鈕時觸發
         confirm(e){
         this.search(e.detail.value)
         },
         search(key){
         var that=this;
         //從本地緩存中異步獲取指定 key 的內容
         var list=wx.getStorage({
         key: 'list',
         //從Storage中取出存儲的數據
         success: function(res) {
         // console.log(res)
         if(key==''){ //用戶沒有輸入時全部顯示
         that.setData({
         list:res.data
         })
         return;
         }
         var arr=[]; //臨時數組,用于存放匹配到的數組
         for(let i in res.data){
         res.data[i].show=false; //所有數據隱藏
         if (res.data[i].search.indexOf(key)>=0){
         res.data[i].show = true; //讓匹配到的數據顯示
         arr.push(res.data[i])
         }
         }
         if(arr.length==0){
         that.setData({
         list:[{show:true,name:'沒有相關數據!'}]
         })
         }else{
         that.setData({
         list: arr
         })
         }
         },
         })
         },
         /**
         * 生命周期函數--監聽頁面加載
         */
         onLoad: function (options) {
         var list=[
         {name: "西安市第一人民醫院", show: true, search:"西安市第一人民醫院"},
         {name: "西安市第二人民醫院", show: true, search: "西安市第二人民醫院" },
         {name: "蘭州市第一人民醫院", show: true, search: "蘭州市第一人民醫院" },
         {name: "蘭州市第二人民醫院", show: true, search: "蘭州市第二人民醫院" }
         ]
         wx.setStorage({
         key: 'list',
         data: list
         })
         this.setData({
         list:list
         })
         },
        })

        效果圖

        條件搜索

        searchif.wxml

        <!--pages/searchif/searchif.wxml-->
        <view class='search'>
         <input type='text'
         bindblur='input'/>
         <button type='primary' class='btn' size='mini'>搜索</button>
         <view wx:for="{{list}}" wx:key='' class='lists'>
         <text wx:if="{{list}}">{{item.name}}</text>
         </view>
        </view>

        searchif.wxss

        /* pages/searchif/searchif.wxss */
        .search{
         padding-left: 10px;
        }
        .search input{
         border:1px solid #ccc;
         border-radius: 6px;
         height: 30px;
         display: inline-block;
         padding-left: 5px;
        }
        .btn{
         height: 32px;
         margin-left: 10px;
        }
        .lists{
         text-align: center;
         margin-top: 20px;
         color: rgb(230, 124, 25);
        }

        searchif.js

        // pages/searchif/searchif.js
        Page({
         /**
         * 頁面的初始數據
         */
         data: {
         list: []
         },
         //鍵盤輸入時實時調用搜索方法
         input(e) {
         this.search(e.detail.value)
         },
         search(key) {
         var that = this;
         //從本地緩存中異步獲取指定 key 的內容
         var list = wx.getStorage({
         key: 'list',
         //從Storage中取出存儲的數據
         success: function (res) {
         // console.log(res)
         if (key == '') { //用戶沒有輸入時全部顯示
         that.setData({
         list: res.data
         })
         return;
         }
         var arr = []; //臨時數組,用于存放匹配到的數組
         for (let i in res.data) {
         if (res.data[i].name.indexOf(key) >= 0) {
         arr.push(res.data[i])
         }
         }
         if (arr.length == 0) {
         that.setData({
         list: [{ name: '沒有相關數據!' }]
         })
         } else {
         that.setData({
         list: arr
         })
         }
         },
         })
         },
         /**
         * 生命周期函數--監聽頁面加載
         */
         onLoad: function (options) {
         var list = [
         { name: "西安市第一人民醫院"},
         { name: "西安市第二人民醫院"},
         { name: "蘭州市第一人民醫院"},
         { name: "蘭州市第二人民醫院"}
         ]
         wx.setStorage({
         key: 'list',
         data: list
         })
         this.setData({
         list: list
         })
         },
        })

        效果圖

        遇到的問題

        在小程序文檔中的setStorage里面的代碼是這樣寫的:

        wx.setStorage({
         key:"key",
         data:"value"
        })

        在此過程中,我在data后面的值也加了引號,結果會出錯,數據拿不到,因此,要注意此處的坑吆! \color{red}{在此過程中,我在data后面的值也加了引號,結果會出錯,數據拿不到,因此,要注意此處的坑吆!}在此過程中,我在data后面的值也加了引號,結果會出錯,數據拿不到,因此,要注意此處的坑吆!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        小程序實現搜索框

        小程序實現搜索框:小程序中搜索框的簡單實現,供大家參考,具體內容如下 搜索框 搜索框無論是在電商網站還是小程序中是很常見的,那么在小程序中是如何實現的呢,我們一起來看看吧(過程遇到很多問題)。 思路 在搜索框中輸入關鍵詞時,應該會向服務器發送請求,因為沒有相關接
        推薦度:
        標簽: 小程序 搜索 開發
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲AV无码成人专区片在线观看| 亚洲人成国产精品无码| 666精品国产精品亚洲| 人人玩人人添人人澡免费| 亚洲精品无码永久在线观看你懂的| 一级视频免费观看| 国产亚洲精久久久久久无码AV| j8又粗又长又硬又爽免费视频| 亚洲七七久久精品中文国产| 一级做a爱片特黄在线观看免费看 一级做a爱过程免费视 | 久久久久久久岛国免费播放| 亚洲AV无码成人精品区在线观看 | 性xxxxx大片免费视频| 久久亚洲熟女cc98cm| 免费看成人AA片无码视频羞羞网| 亚洲欧洲日韩极速播放| 日本一道一区二区免费看 | 国产精品另类激情久久久免费| 亚洲av永久无码| 亚洲国产精品自产在线播放| 国产又黄又爽又大的免费视频| 色噜噜综合亚洲av中文无码| 中文毛片无遮挡高潮免费| 亚洲JIZZJIZZ妇女| 久久精品国产亚洲7777| 国产精品99久久免费观看| 色偷偷亚洲女人天堂观看欧| 免费A级毛片无码A∨男男| 成av免费大片黄在线观看| 亚洲国产一区在线观看| 婷婷亚洲天堂影院| 日本免费在线中文字幕| 亚洲熟女综合一区二区三区| 亚洲性久久久影院| ww4545四虎永久免费地址| 深夜a级毛片免费无码| 99亚洲精品高清一二区| 国产精品久久免费视频| 99视频有精品视频免费观看 | 一级特黄特色的免费大片视频| 亚洲欧洲国产精品你懂的|