当在数据量不是很大,而且没有后端对应的功能接口的时候,一些简单的搜索功能基本上是前端去实现的,正好最近用到,写了一个,贴出来和大家分享:
效果图:
功能描述:
按下键盘后及时搜索条目中的汉字,汉字对应的拼音和号码;
实现思路:
先将条目中的汉字转换成拼音,然后将汉字,拼音,数字拼接成规律的字符串,放入数组,然后每次按下键盘后判断 input 中的值是汉字,拼音,还是数字,然后按固定的规律去循环数组,这样就能找到对应的条目了;
启用方式:
// search-test-inner ---> 最外层div
// search-value ---> input 输入框
// search-value-list ---> 搜索结果显示div
// search-li ---> 搜索条目
new SEARCH_ENGINE("search-test-inner","search-value","search-value-list","search-li");
注意:搜索条目加上两个临时数据,data-name 和 data-phone ,用来存储汉字和数字。
说明:拼音的转换用到了一个叫 jQuery.Hz2Py-min.js 的插件,由于这个插件只能转换 input 里的值,所以代码里多了一个步骤,先将值放入一个临时的 input ,再转换。
HTML:
复制代码 代码如下:
<div class="search-test-inner">
<div class="search-val-inner">
<input type="text" class="search-value" placeholder="搜索">
<ul class="search-value-list"></ul>
</div>
<div class="member-list-inner">
<ul>
<li class="search-li" data-name="战士" data-phone="13914157895">
<span class="phone">13914157895</span>
<span class="name">战士</span>
</li>
<li class="search-li" data-name="牧师" data-phone="15112357896">
<span class="phone">15112357896</span>
<span class="name">牧师</span>
</li>
<li class="search-li" data-name="盗贼" data-phone="13732459980">
<span class="phone">13732459980</span>
<span class="name">盗贼</span>
</li>
<li class="search-li" data-name="德鲁伊" data-phone="18015942365">
<span class="phone">18015942365</span>
<span class="name">德鲁伊</span>
</li>
<li class="search-li" data-name="武僧" data-phone="15312485698">
<span class="phone">15312485698</span>
<span class="name">武僧</span>
</li>
<li class="search-li" data-name="死灵法师" data-phone="13815963258">
<span class="phone">13815963258</span>
<span class="name">死灵法师</span>
</li>
<li class="search-li" data-name="圣骑士" data-phone="13815934258">
<span class="phone">13815934258</span>
<span class="name">圣骑士</span>
</li>
</ul>
</div>
</div>
CSS:
复制代码 代码如下:
* { padding: 0; margin: 0; }
ol , ul { list-style: none; }
body { font-size: 12px; color:#333; }
.search-test-inner { margin: 100px auto; padding: 10px; width: 400px; background: #e0e0e0; border-radius: 10px; box-shadow: 1px 2px 6px #444; }
.search-val-inner { margin-bottom: 20px; padding: 10px; background: #fff; }
.member-list-inner .search-li { padding: 10px; }
.search-value-list { margin-top: 10px; }
.search-value-list li { padding: 5px; }
.member-list-inner .search-li .phone,
.search-value-list li .phone { float: right; }
.search-value { width: 100%; height: 30px; line-height: 30px; }
.tips { font-weight: bold; }
JS:
复制代码 代码如下:
//---------------------------------------------------【初始化】
function SEARCH_ENGINE(dom,searchInput,searchResultInner,searchList){
//存储拼音+汉字+数字的数组
this.searchMemberArray = [];
//作用对象
this.dom = $("." + dom);
//搜索框
this.searchInput = "." + searchInput;
//搜索结果框
this.searchResultInner = this.dom.find("." + searchResultInner);
//搜索对象的名单列表
this.searchList = this.dom.find("." + searchList);
//转换成拼音并存入数组
this.transformPinYin();
//绑定搜索事件
this.searchActiveEvent();
}
SEARCH_ENGINE.prototype = {
//-----------------------------【转换成拼音,并将拼音、汉字、数字存入数组】
transformPinYin : function(){
//临时存放数据对象
$("body").append('<input type="text" class="hidden pingying-box">');
var $pinyin = $("input.pingying-box");
for(var i=0;i<this.searchList.length;i++){
//存放名字,转换成拼音
$pinyin.val(this.searchList.eq(i).attr("data-name"));
//汉字转换成拼音
var pinyin = $pinyin.toPinyin().toLowerCase().replace(/s/g,"");
//汉字
var cnCharacter = this.searchList.eq(i).attr("data-name");
//数字
var digital = this.searchList.eq(i).attr("data-phone");
//存入数组
this.searchMemberArray.push(pinyin + "&" + cnCharacter + "&" + digital);
}
//删除临时存放数据对象
$pinyin.remove();
},
//-----------------------------【模糊搜索关键字】
fuzzySearch : function(type,val){
var s;
var returnArray = [];
//拼音
if(type === "pinyin"){
s = 0;
}
//汉字
else if(type === "cnCharacter"){
s = 1;
}
//数字
else if(type === "digital"){
s = 2;
}
for(var i=0;i<this.searchMemberArray.length;i++){
//包含字符
if(this.searchMemberArray[i].split("&")[s].indexOf(val) >= 0){
returnArray.push(this.searchMemberArray[i]);
}
}
return returnArray;
},
//-----------------------------【输出搜索结果】
postMemberList : function(tempArray){
var html = '';
//有搜索结果
if(tempArray.length > 0){
html += '<li class="tips">搜索结果(' + tempArray.length + ')</li>';
for(var i=0;i<tempArray.length;i++){
var sArray = tempArray[i].split("&");
html += '<li>';
html += '<span class="phone">' + sArray[2] + '</span>';
html += '<span class="name">' + sArray[1] + '</span>';
html += '</li>';
}
}
//无搜索结果
else{
if($(this.searchInput).val() != ""){
html += '<li class="tips">无搜索结果……</li>';
}else{
this.searchResultInner.html("");
}
}
this.searchResultInner.html(html);
},
//-----------------------------【绑定搜索事件】
searchActiveEvent : function(){
var searchEngine = this;
$(document).on("keyup",this.searchInput,function(){
//临时存放找到的数组
var tempArray = [];
var val = $(this).val();
//判断拼音的正则
var pinYinRule = /^[A-Za-z]+$/;
//判断汉字的正则
var cnCharacterRule = new RegExp("^[\u4E00-\u9FFF]+$","g");
//判断整数的正则
var digitalRule = /^[-+]"pinyin",val);
}
//汉字
else if(cnCharacterRule.test(val)){
tempArray = searchEngine.fuzzySearch("cnCharacter",val);
}
//数字
else if(digitalRule.test(val)){
tempArray = searchEngine.fuzzySearch("digital",val);
}
else{
searchEngine.searchResultInner.html('<li class="tips">无搜索结果……</li>');
}
searchEngine.postMemberList(tempArray);
});
}
};
效果是不是非常棒呢,小伙伴们美化下就可以用到自己项目中了
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]