对本网站【青柠知秋】大神,自定义mui 搜索列表插件 picker-search,修改为对数据库中数据进行模糊搜索
先向大神致敬吧!!!链接: 自定义mui 搜索列表插件 picker-search.
最近在做手机网站,但我是个小白从没做过移动端网站,从网上找到了MUI,修修改改做的挺丑的(不会前端及UI,特别痛苦)。
MUI下的选择器picker没有搜索功能,不符合要求,继续在网上搜索找到了【青柠知秋】大神的自定义插件 自定义mui 搜索列表插件 picker-search,如获至宝,欣喜异常~
但是,使用后发现只符合项目中的部分功能,没办法只好继续对其进行修改,说说遇到的情况,然后上代码吧。
1、要在【picker-search】插件中放入大量的数据,然后进行搜索,选择。
2、但是现有的插件在初始化时,一次性放入大量数据,会导致运行速度极慢。
3、这时,有个想法就是,初始化时只放少量数据,然后进行搜索时,不查询现有数据,
而是使用查询条件到数据库重新获取数据。
上代码吧。
//直接修改【myMuiSearchPicker.js】中的搜索代码
self.input.addEventListener('input', function () {
self.panel.style.top = self.top;
self.searchClean = self.input.nextSibling;
self.searchClean.addEventListener('tap', sc, false);
var filter = this.value; //获取搜索框中的数据,这是【青柠知秋】大神的原代码
//修改的代码开始
$.ajax({
url: "/MobileManage/Mobile/GetProductList?name=" + filter,
type: "get",//请求方式
dataType: 'json',//服务器返回json格式数据
async: false,
//请求成功
success: function (ret) {
self.setData(ret); //重新给选择器赋值
},
//请求失败,包含具体的错误信息
error: function (e) {
self.setData(self.options.data);//如果查询出错,则赋值原有数据
}
});
//修改的代码结束
/* 这是【青柠知秋】大神的原代码
var filterList = [];
if (filter) {
for (var i = 0; i < self.options.data.length; i++) {
if (self.options.data[i].text.search(filter) != -1) {
filterList.push(self.options.data[i]);
}
}
self.setData(filterList);
} else {
self.setData(self.options.data);
}*/
self.pickers[0].setSelectedIndex(0, 1000);
}, false);