使用SAE KVDB快速实现 支持中文/拼音/全拼/的AutoComplete
jQueryUI的AutoComplete是一个好东西,但是无奈不支持中文,有好几次想在产品中添加这个功能但都因为用PHP实现一个中文 还要拼音和全拼的索引太过麻烦而最终放弃.
在开发这个火车票交易项目的时候,发现SAE的KVDB是个好东西,使用前缀查询可以轻松实现中文的自动完成的支持,正好现在项目因为实名制已经砍掉了有时间,就把这个发现分享给大家 作为我在CSDN的第一篇博客:)))
SAE的KVDB是一个Key/Value存储引擎,也就是noSQL. 测试了一下性能竟然比SAE的MC都高 大家可以先看一下文档 http://sae.sina.com.cn/?m=devcenter&catId=199
同学们可以先看一下我们的应用 输入be就会自动提示相关的站名
插件交互的流程是 插件将输入的字符'be'使用GET的方式发送给服务器 服务器返回拼音或全拼由这个两个字符开头的所有车站的站名
前端的代码大家可以参考jQueryUI的文档 非常详细我就不罗嗦哦了 http://jqueryui.com/demos/autocomplete/
关键代码只有三行:
$('.stops').autocomplete({source: "http://huijiala.sinaapp.com/stop.php",minLength: 1,});
这个JSON串的返回才是最头疼的,但是使用KVDB的pkrget 前缀范围查找 方法就很轻松了这个方法可以把所有含有相同前缀的KEY的值全部取出来.看到这个方法后本来很头疼的这个问题已经完全是小菜一碟了 我们只要将拼音和全拼作为key将 对应的站点信息作为value存到KVDB里就可以了
下面是具体的实现 :
<?
header("Content-type: application/json");
echo '[';
$reslut='';
if(@$key=$_GET['term']){$kv = new SaeKV();$ret = $kv->init(); $mc=memcache_init();function getraw($pkrkey,$kv){$value='';$ret = $kv->pkrget($pkrkey, 100); while (true) {foreach($ret as $k => $v){$value.=$v;}; end($ret);$start_key = key($ret);$i = count($ret);if ($i < 100) break;$ret = $kv->pkrget($pkrkey, 100, $start_key);}return $value;}//输出if( !@$reslut=$mc->get($key)){//如果mc失败$reslut.=getraw('acHZ'.$key,$kv);$reslut.=getraw('acJP'.$key,$kv);$reslut.=getraw('acQP'.$key,$kv);if ($reslut){$mc->set($key,$reslut);};}
}
if ($reslut=='') { $reslut='{"label":"没有该站","value":""}'; };
echo $reslut;
echo '{"":""}]';
?>
使用SAE KVDB快速实现 支持中文/拼音/全拼/的AutoComplete相关推荐
- 将中文汉字转换成拼音(全拼)
using System.Globalization; using System.Text; using System.Text.RegularExpressions;/// <summary& ...
- js 处理-按中文/拼音/简拼检索
把输入框的内容 中文/拼音/简拼 匹配出城市列表. 首先引入formate.js 使用时 import formate from './formate.js' var arr = [], ser ...
- java实现大段中文转拼音首字母、拼音全拼
话不多说,上代码: package cn.jiangshuai.personManage;import java.util.Scanner;import net.sourceforge.pinyin4 ...
- java汉字转拼音(全拼、简拼)
java汉字转拼音(全拼.简拼) <dependency><groupId>com.belerweb</groupId><artifactId>piny ...
- java将汉字转成拼音首字母大写字母_java 根据汉字生成拼音全拼或拼音首字母的示例...
1.情景展示 java 根据中文生成对应的拼音 2.准备工作 所需jar包:pinyin4j-2.5.0.jar 3.解决方案 导包 import net.sourceforge.pinyin4j.P ...
- sql文字转换全拼_SQL自定义函数:由汉字生成拼音全拼
SQL自定义函数:由汉字生成拼音全拼 CREATE function [dbo].[fun_GetPy_quanpin](@str varchar(100)) returns varchar(8000 ...
- Delphi汉字转拼音全拼
查询了很多网上汉字转拼音的方案,一种是用VBA实现的,另一种是只能转汉字首字母,结合VBA的方式,用Delphi实现汉字转拼音全拼的方法.附Delphi7写的例程链接 Delphi实现汉字转拼音全拼的 ...
- 让你的查询支持中文拼音码模糊查询。
需求:在做软件的过程中,发现不少客户在做数据检索时,打汉字怕麻烦,也影响工作效率,要求在查询时,支持查询汉字的字母开头查询. 做到支持数据库拼音码查询,主要分一下几步实现: 1.在数据库中建立一个sy ...
- Qt5应用内嵌输入法(支持中文拼音输入、英文输入、数字输入、常用符号输入、手写输入、实体键盘同步)
声明:部分有参考csdn其他牛人的资料,现将代码共享,共同学习,来源于社会,回馈社会. 一.概述 有用过Qt虚拟键盘的同志都知道,Qt的虚拟键盘确实很强大,特别是Qt5自带的的虚拟键盘,支持多国语言输 ...
最新文章
- web项目数据存入mysql数据库中文乱码问题
- 什么样的代码为好代码?好代码的科学定义
- 打包phar文件过大的问题。
- 为什么要继承Serializable类?
- C++知识点15——使用C++标准库(IO流)
- 《Think Python》最新中文版火了,附完整PDF下载!
- C++中常量成员函数的含义
- Docker运行操作系统环境(BusyBoxAlpineDebian/UbuntuCentOS/Fedora)
- 一篇文章搞懂数据仓库:数据仓库架构-Lambda和Kappa对比
- MySQL故障检测_检测MySQL的表的故障的方法
- PHP登录表单提交前端验证,form表单提交前先用ajax进行验证(前端)
- mysql如何使用事件_MySQL事件的使用详解
- 中间滑动 头部底部固定_固定抗震弹性支座报价技术参数
- css @语法,@规则 @import @charset @font-face @fontdef @media @page
- python获取小王的ip地址_用Python获取本机的IP地址
- 什么?iPhone 11起售价不到5400元?
- Java多线程(join方法)
- 防火墙双机热备A/S模式和A/A模式原理
- python生成excel文件二维码_Python实现读取Excel表内容批量生成二维码
- tl-wn821n无线网卡驱动 linux,tl-wn821n无线网卡驱动下载
热门文章
- 基于JSP的网上银行系统开发与设计
- linux命令grep不区分大小写,Linux grep 命令大全
- VBA 批量打开workbook工作簿,汇总到同一workbook工作簿中
- 人工智能实验实训室解决方案-人工智能实训基地建设方案
- 给青海玉树捐款账号是什么--百度快照查看
- C语言521短整型输出,printf 格式输出
- 计算机无法访问iTunes,iTunes无法连接到计算机上的iTunes Store,并且发生未知错误。解决方法...
- Linux学习随笔(基础篇)-- 文件权限
- 何川, 周军. 具有直线结构保护的网格化图像拼接[J]. 中国图象图形学报, 2018
- Java 愤怒的小鸟游戏