实现历史记录逻辑

//搜索的时候缓存到本地
  searchBox() {
    let searchValue= this.data.searchValue
    let searchList= this.data.searchList ;
//保持5条历史记录
      if (searchList.length < 5) {
        searchList.unshift(searchValue);
      } else {
        searchList.pop();
        searchList.unshift(searchValue);
      }
      //将历史记录数组整体储存到缓存中
      wx.setStorageSync('searchList', Array.from(new Set(searchList)));
  },

 

实现搜索栏的历史记录,你可以使用 XML(或者更常见的 JSON)来存储搜索历史数据。以下是一个使用 XML 实现搜索栏历史记录的示例: ```xml <searchHistory> <record>Search term 1</record> <record>Search term 2</record> <record>Search term 3</record> </searchHistory> ``` 在上述示例中,`<searchHistory>` 是根元素,`<record>` 是存储每个搜索记录的子元素。你可以在 `<record>` 元素中存储每个搜索条目的文本内容。 在 JavaScript 中,你可以使用 XMLHttpRequest 或 Fetch API 来读取和写入 XML 数据。以下是一个使用 XMLHttpRequest 的示例代码: ```javascript // 读取搜索历史记录 function getSearchHistory() { const xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState === 4 && this.status === 200) { const xmlDoc = this.responseXML; const records = xmlDoc.getElementsByTagName("record"); // 遍历搜索记录并处理 for (let i = 0; i < records.length; i++) { const record = records[i].textContent; // 在这里进行处理,例如显示到页面上 console.log(record); } } }; xhttp.open("GET", "searchHistory.xml", true); xhttp.send(); } // 写入搜索历史记录 function addSearchTerm(term) { const xhttp = new XMLHttpRequest(); xhttp.open("POST", "addSearchTerm.php", true); // 这里的 "addSearchTerm.php" 应该是处理写入逻辑的服务器端脚本 xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhttp.send("term=" + term); } ``` 在上述示例中,`getSearchHistory` 函数使用 XMLHttpRequest 发起一个 GET 请求来获取搜索历史记录的 XML 数据。然后,它将 XML 数据解析为 DOM 对象,遍历 `<record>` 元素,并将每个记录的文本内容进行处理(在示例中只是简单地打印到控制台)。 `addSearchTerm` 函数使用 XMLHttpRequest 发起一个 POST 请求,将搜索条目作为参数发送到服务器端脚本进行处理。服务器端脚本负责将新的搜索条目添加到 XML 文件中。 请注意,这只是一个基本示例,实际情况中你可能需要根据自己的需求进行适当的修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值