Vue+localStorage历史搜索
2019-06-19 本文已影响0人
若沫成海
<div class="header-middle">
<input
type="text"
class="header-input"
placeholder="输入城市或景点"
v-model="inputMsg"/>
</div>
<div class="header-right" @click="handleClickSeach">搜索</div>
export default {
name:'TicketHeader',
data:function(){
return{
inputMsg:'',
historySearch:[]
}
},
methods:{
handleClickSeach(){
if(this.inputMsg!==''){
let storage=window.localStorage
if(storage.getItem('searchWord')==null){
this.historySearch.unshift({keyWord:this.inputMsg})
storage.setItem('searchWord',JSON.stringify(this.historySearch))
}else{
if(!JSON.parse(storage.getItem('searchWord')).find(v => v.keyWord === this.inputMsg)){
if( this.historySearch.length >= 6){
this.historySearch.pop()
}
this.historySearch.unshift({keyWord:this.inputMsg})
storage.setItem('searchWord',JSON.stringify(this.historySearch))
}
}
}
},
created(){
//获取localstorage
let storage=window.localStorage
if(storage.getItem('searchWord')!==null){
this.historySearch=JSON.parse(storage.getItem('searchWord'))
}
}
}
JSON.parse() 方法将字符串转换为 JavaScript 对象
JSON.stringify() 方法是将一个JavaScript值(对象或者数组)转换为一个 JSON字符串