{"id":38169,"date":"2023-07-24T04:42:00","date_gmt":"2023-07-20T04:35:07","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/"},"modified":"2024-04-30T15:04:12","modified_gmt":"2024-04-30T07:04:12","slug":"%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/","title":{"rendered":"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355"},"content":{"rendered":"<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d32f237434c4406c63e18\/0-0.png\" alt=\"Screenshot 2015-07-10 22.15.40.png\" \/><\/div>\n<p>\u603b\u7ed3<\/p>\n<p>React.js\u306e\u5165\u529b\u30d5\u30a9\u30fc\u30e0\u3067jQuery-ui\/Autocomplete\u3092\u5229\u7528\u3057\u3001\u5229\u7528\u8005\u306e\u6587\u5b57\u5217\u5165\u529b\u306b\u5fdc\u3058\u3066\u8a9e\u53e5\u306e\u5019\u88dc\u3092\u30c9\u30ed\u30c3\u30d7\u30c0\u30a6\u30f3\u3067\u8868\u793a\u3059\u308b\u6a5f\u80fd\u3092\u8ffd\u52a0\u3059\u308b\u3002<br \/>\nRails, HAML, CoffeeScript\u3067\u66f8\u3044\u305f\u3002<\/p>\n<p>\u73af\u5883<br \/>\n&#8211; Environment.<\/p>\n<pre class=\"post-pre\"><code>ruby 2.2.1\r\nRails 4.2.1\r\n<\/code><\/pre>\n<p>#\uff08\u4ee5Rails\u4e3a\u4f8b\u7684\uff09\u51c6\u5907\u5de5\u4f5c<\/p>\n<p>\u5c06&#8217;jquery-ui-rails&#8217;\u6dfb\u52a0\u5230Gemfile\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">#jQuery-ui\/Autocomplete\u3092\u4f7f\u3046\u305f\u3081\u3002<\/span>\r\n<span class=\"n\">gem<\/span> <span class=\"s1\">'jquery-ui-rails'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'~&gt; 5.0.5'<\/span>\r\n\r\n<span class=\"c1\">#React.js\u3092\u4f7f\u3046\u305f\u3081\u3002<\/span>\r\n<span class=\"n\">gem<\/span> <span class=\"s1\">'react-rails'<\/span><span class=\"p\">,<\/span>     <span class=\"s1\">'~&gt; 1.0.0'<\/span>\r\n\r\n<span class=\"c1\"># ...\u4ed6<\/span>\r\n<\/code><\/pre>\n<p>\u5c06jquery-ui\/autocomplete\u6dfb\u52a0\u5230application.js\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ \u4f8b<\/span>\r\n<span class=\"c1\">\/\/= require jquery<\/span>\r\n<span class=\"c1\">\/\/= require jquery_ujs<\/span>\r\n<span class=\"c1\">\/\/= require jquery.turbolinks<\/span>\r\n<span class=\"c1\">\/\/= require bootstrap<\/span>\r\n<span class=\"c1\">\/\/= require turbolinks<\/span>\r\n<span class=\"c1\">\/\/= require jquery-ui\/autocomplete<\/span>\r\n<span class=\"c1\">\/\/= require react<\/span>\r\n<span class=\"c1\">\/\/= require react_ujs<\/span>\r\n<span class=\"c1\">\/\/= require growl<\/span>\r\n<span class=\"c1\">\/\/= require components<\/span>\r\n<span class=\"c1\">\/\/= requre_tree .<\/span>\r\n<\/code><\/pre>\n<p>\u65b0\u6570\u636e\u8f93\u5165\u8868\u683c\u7684\u5904\u7406\u6d41\u7a0b<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u8868\u4f5c\u6210\u7528\u306e\u30c7\u30fc\u30bf\u3068\u3068\u3082\u306b\u3001\u30ab\u30c6\u30b4\u30ea\u30fc\u540d\u79f0\u3068\u90e8\u5c4b\u540d\u79f0\u306e\u30c7\u30fc\u30bf\u3092\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u304b\u3089\u53d6\u308a\u51fa\u3057\u3001\u914d\u5217\u3068\u3057\u3066\u90e8\u54c1\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u6642\u306b\u6e21\u3057\u3066\u304a\u304f\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30e6\u30fc\u30b6\u30fc\u304c\u5165\u529b\u3057\u305f\u5185\u5bb9\u306b\u53cd\u5fdc\u3057\u3066\u305d\u306e\u6587\u5b57\u3092\u542b\u3080\u8a9e\u53e5\u3092\u5019\u88dc\u3068\u3057\u3066\u8868\u793a\u3059\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u8a9e\u53e5\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u305d\u308c\u304c\u5165\u529b\u30c7\u30fc\u30bf\u3068\u3057\u3066\u53d6\u308a\u6271\u308f\u308c\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30c7\u30fc\u30bf\u3092\u691c\u8a3c\u3057\u3001OK\u3067\u3042\u308c\u3070\u3001\u63d0\u51fa\u30dc\u30bf\u30f3\u304c\u6709\u52b9\u306b\u306a\u308a\u3001\u63d0\u51fa\u53ef\u80fd\u306b\u306a\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30c7\u30fc\u30bf\u306fXHR\u3067\u30b5\u30fc\u30d0\u30fc\u306b\u9001\u4fe1\u3055\u308c\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u4fdd\u5b58\u3055\u308c\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u90e8\u54c1\u306eUI\u3082\u72b6\u614b\u30c7\u30fc\u30bf\u3092\u5143\u306b\u66f4\u65b0\u3055\u308c\u308b\u3002\uff08\u65b0\u898f\u30c7\u30fc\u30bf\uff09\u304c\u8868\u306b\u8ffd\u52a0\u3055\u308c\u308b\u3002<\/ul>\n<p>1. \u4e3b\u8981\u7684\u96f6\u4ef6<\/p>\n<pre class=\"post-pre\"><code>\r\n<span class=\"vi\">@<\/span><span class=\"na\">RecordsApp<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">createClass<\/span>\r\n  <span class=\"c1\"># \u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u6642\u306b\u53d7\u3051\u53d6\u3063\u305f\u30c7\u30fc\u30bf\uff08\u8868\u3092\u4f5c\u6210\u3059\u308b\u30c7\u30fc\u30bf\uff09\u3092\u899a\u3048\u3066\u304a\u304f\u3002<\/span>\r\n  <span class=\"na\">getInitialState<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"na\">records<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">props<\/span><span class=\"p\">.<\/span><span class=\"na\">data<\/span>\r\n\r\n  <span class=\"na\">getDefaultProps<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"na\">records<\/span><span class=\"o\">:<\/span> <span class=\"p\">[]<\/span>\r\n\r\n  <span class=\"c1\"># \u65b0\u898f\u4f5c\u6210\u7528\u30d5\u30a9\u30fc\u30e0\u306b\u5165\u529b\u3055\u308c\u305f\u5185\u5bb9\u3067\u30c7\u30fc\u30bf\u3092\u8ffd\u52a0\u3059\u308b\u3002\u305d\u3057\u3066UI\u3092\u66f4\u65b0\u3002<\/span>\r\n  <span class=\"na\">addRecord<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">record<\/span><span class=\"p\">)<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"nx\">records<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">addons<\/span><span class=\"p\">.<\/span><span class=\"na\">update<\/span><span class=\"p\">(<\/span><span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">records<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"na\">$unshift<\/span><span class=\"o\">:<\/span> <span class=\"p\">[<\/span><span class=\"nx\">record<\/span><span class=\"p\">]<\/span> <span class=\"p\">})<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">setState<\/span> <span class=\"na\">records<\/span><span class=\"o\">:<\/span> <span class=\"nx\">records<\/span>\r\n\r\n  <span class=\"c1\">#\uff08\u4e2d\u7565\uff09<\/span>\r\n\r\n  <span class=\"na\">render<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"c1\"># React.DOM\u8a18\u8ff0\u3092\u7701\u7565\u3059\u308b\u76ee\u7684\u306e\u4e00\u6642\u5909\u6570\u3002<\/span>\r\n    <span class=\"nx\">R<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">DOM<\/span>\r\n\r\n    <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n      <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">h2<\/span> <span class=\"no\">null<\/span><span class=\"p\">,<\/span> <span class=\"s\">\"Add a new item\"<\/span>\r\n\r\n      <span class=\"c1\"># \u65b0\u898f\u4f5c\u6210\u30d5\u30a9\u30fc\u30e0<\/span>\r\n      <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">createElement<\/span> <span class=\"nx\">NewMovingRecordForm<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"c1\"># \u65b0\u898f\u30c7\u30fc\u30bf\u51e6\u7406\u7528\u306e\u30e1\u30bd\u30c3\u30c9\u3092\u6e21\u3059\u3002<\/span>\r\n        <span class=\"na\">handleNewRecord<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">addRecord<\/span>\r\n        <span class=\"c1\"># \u8a9e\u53e5\u5019\u88dc\u306e\u30c7\u30fc\u30bf\u3092\u6e21\u3059\u3002<\/span>\r\n        <span class=\"na\">roomSuggestions<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">props<\/span><span class=\"p\">.<\/span><span class=\"na\">roomSuggestions<\/span>\r\n        <span class=\"na\">categorySuggestions<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">props<\/span><span class=\"p\">.<\/span><span class=\"na\">categorySuggestions<\/span>\r\n      <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">hr<\/span> <span class=\"no\">null<\/span>\r\n\r\n      <span class=\"c1\"># \u8868<\/span>\r\n      <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">createElement<\/span> <span class=\"nx\">Records<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"na\">records<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">records<\/span><span class=\"p\">,<\/span>\r\n<\/code><\/pre>\n<p>2. \u521b\u5efa\u65b0\u7684\u8868\u5355\u7ec4\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"vi\">@<\/span><span class=\"na\">NewMovingRecordForm<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">createClass<\/span>\r\n  <span class=\"c1\"># \u5143\u306e\u72b6\u614b<\/span>\r\n  <span class=\"na\">getInitialState<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">\"\"<\/span>\r\n    <span class=\"na\">volume<\/span><span class=\"o\">:<\/span>      <span class=\"s\">\"\"<\/span>\r\n    <span class=\"na\">quantity<\/span><span class=\"o\">:<\/span>    <span class=\"s\">\"\"<\/span>\r\n    <span class=\"na\">room<\/span><span class=\"o\">:<\/span>        <span class=\"s\">\"\"<\/span>\r\n    <span class=\"na\">category<\/span><span class=\"o\">:<\/span>    <span class=\"s\">\"\"<\/span>\r\n    <span class=\"na\">description<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"\"<\/span>\r\n\r\n  <span class=\"c1\"># \u4e00\u5b57\u4e00\u53e5\u5165\u529b\u6642\u306b\u72b6\u614b\u30c7\u30fc\u30bf\u3092\u66f4\u65b0\u3059\u308b\u3002<\/span>\r\n  <span class=\"na\">handleChange<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">)<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"nx\">name<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"na\">target<\/span><span class=\"p\">.<\/span><span class=\"na\">name<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">setState<\/span> <span class=\"s\">\"<\/span><span class=\"si\">#{<\/span> <span class=\"nx\">name<\/span> <span class=\"si\">}<\/span><span class=\"s\">\"<\/span><span class=\"o\">:<\/span> <span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"na\">target<\/span><span class=\"p\">.<\/span><span class=\"na\">value<\/span>\r\n\r\n  <span class=\"c1\"># \u63d0\u51fa\u30dc\u30bf\u30f3\u304c\u62bc\u3055\u308c\u305f\u6642\u306e\u51e6\u7406\u3092\u3053\u3053\u306b\u8a18\u8ff0\u3059\u308b\u3002<\/span>\r\n  <span class=\"na\">handleSubmit<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">)<\/span> <span class=\"o\">-&gt;<\/span>\r\n\r\n  <span class=\"c1\"># UI\u3092\u5143\u306e\u72b6\u614b\uff08\u7a7a\u30d5\u30a9\u30fc\u30e0\uff09\u306b\u623b\u3059\u3002<\/span>\r\n  <span class=\"na\">handleClear<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">)<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">setState<\/span> <span class=\"vi\">@<\/span><span class=\"na\">getInitialState<\/span><span class=\"p\">()<\/span>\r\n\r\n  <span class=\"c1\"># \u5165\u529b\u5185\u5bb9\u306e\u691c\u8a3c<\/span>\r\n  <span class=\"na\">valid<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">validName<\/span><span class=\"p\">()<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">validVolume<\/span><span class=\"p\">()<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">validQuantity<\/span><span class=\"p\">()<\/span> <span class=\"o\">&amp;&amp;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">validRoom<\/span><span class=\"p\">()<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">validCategory<\/span><span class=\"p\">()<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">validDescription<\/span><span class=\"p\">()<\/span>\r\n  <span class=\"na\">validName<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">name<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">name<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">50<\/span>\r\n  <span class=\"na\">validVolume<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">volume<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">volume<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">10<\/span>\r\n  <span class=\"na\">validQuantity<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">quantity<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">quantity<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">10<\/span>\r\n  <span class=\"na\">validRoom<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">room<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">room<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">50<\/span>\r\n  <span class=\"na\">validCategory<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">category<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">category<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">50<\/span>\r\n  <span class=\"na\">validDescription<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">description<\/span><span class=\"p\">.<\/span><span class=\"na\">length<\/span> <span class=\"o\">&lt;=<\/span> <span class=\"mi\">200<\/span>\r\n\r\n  <span class=\"c1\"># React\u306b\u3088\u308a\u30de\u30fc\u30af\u30a2\u30c3\u30d7\u304c\u751f\u6210\u3055\u308c\u305f\u76f4\u5f8c\u306b\u547c\u3070\u308c\u308b\u3002\u3053\u3053\u3067jQuery\u304c\u5b9f\u969b\u306eDOM\u306b\u5bfe\u3057\u3066Autocomplete\u3092\u521d\u671f\u5316\u3059\u308b\u3002(React\u306f\u77e5\u3089\u306a\u3044\uff09<\/span>\r\n  <span class=\"na\">componentDidMount<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">updateAutocomplete<\/span><span class=\"p\">()<\/span>\r\n\r\n  <span class=\"c1\"># React\u306b\u3088\u308a\u30de\u30fc\u30af\u30a2\u30c3\u30d7\u304c\u66f4\u65b0\u3055\u308c\u305f\u76f4\u5f8c\u306b\u547c\u3070\u308c\u308b\u3002\u3053\u3053\u3067Autocomplete\u3092\u66f4\u65b0\u3059\u308b\u3002<\/span>\r\n  <span class=\"na\">componentDidUpdate<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"vi\">@<\/span><span class=\"na\">updateAutocomplete<\/span><span class=\"p\">()<\/span>\r\n\r\n  <span class=\"c1\"># jQuery\u304c\u4f5c\u3063\u305fAutocomplete\u3092\u6d88\u53bb\u3059\u308b\u3002<\/span>\r\n  <span class=\"na\">componentWillUnmount<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"nx\">$<\/span><span class=\"p\">(<\/span><span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">findDOMNode<\/span><span class=\"p\">(<\/span><span class=\"vi\">@<\/span><span class=\"na\">refs<\/span><span class=\"p\">.<\/span><span class=\"na\">room<\/span><span class=\"p\">)).<\/span><span class=\"na\">autocomplete<\/span><span class=\"p\">(<\/span><span class=\"s\">'destroy'<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"nx\">$<\/span><span class=\"p\">(<\/span><span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">findDOMNode<\/span><span class=\"p\">(<\/span><span class=\"vi\">@<\/span><span class=\"na\">refs<\/span><span class=\"p\">.<\/span><span class=\"na\">category<\/span><span class=\"p\">)).<\/span><span class=\"na\">autocomplete<\/span><span class=\"p\">(<\/span><span class=\"s\">'destroy'<\/span><span class=\"p\">)<\/span>\r\n\r\n  <span class=\"c1\"># Autocomplete\u521d\u671f\u5316\u30fb\u66f4\u65b0\u306e\u51e6\u7406\u3002<\/span>\r\n  <span class=\"na\">updateAutocomplete<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"nx\">$<\/span><span class=\"p\">(<\/span><span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">findDOMNode<\/span><span class=\"p\">(<\/span><span class=\"vi\">@<\/span><span class=\"na\">refs<\/span><span class=\"p\">.<\/span><span class=\"na\">room<\/span><span class=\"p\">)).<\/span><span class=\"na\">autocomplete<\/span>\r\n      <span class=\"na\">source<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">props<\/span><span class=\"p\">.<\/span><span class=\"na\">roomSuggestions<\/span>\r\n      <span class=\"na\">select<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">,<\/span> <span class=\"nx\">ui<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span>\r\n        <span class=\"vi\">@<\/span><span class=\"na\">setState<\/span> <span class=\"na\">room<\/span><span class=\"o\">:<\/span> <span class=\"nx\">ui<\/span><span class=\"p\">.<\/span><span class=\"na\">item<\/span><span class=\"p\">.<\/span><span class=\"na\">value<\/span>\r\n\r\n    <span class=\"nx\">$<\/span><span class=\"p\">(<\/span><span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">findDOMNode<\/span><span class=\"p\">(<\/span><span class=\"vi\">@<\/span><span class=\"na\">refs<\/span><span class=\"p\">.<\/span><span class=\"na\">category<\/span><span class=\"p\">)).<\/span><span class=\"na\">autocomplete<\/span>\r\n      <span class=\"na\">source<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">props<\/span><span class=\"p\">.<\/span><span class=\"na\">categorySuggestions<\/span>\r\n      <span class=\"na\">select<\/span><span class=\"o\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">,<\/span> <span class=\"nx\">ui<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span>\r\n        <span class=\"vi\">@<\/span><span class=\"na\">setState<\/span> <span class=\"na\">category<\/span><span class=\"o\">:<\/span> <span class=\"nx\">ui<\/span><span class=\"p\">.<\/span><span class=\"na\">item<\/span><span class=\"p\">.<\/span><span class=\"na\">value<\/span>\r\n\r\n  <span class=\"na\">render<\/span><span class=\"o\">:<\/span> <span class=\"o\">-&gt;<\/span>\r\n    <span class=\"nx\">R<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"na\">DOM<\/span>\r\n\r\n    <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">form<\/span>\r\n      <span class=\"na\">onSubmit<\/span><span class=\"o\">:<\/span>  <span class=\"vi\">@<\/span><span class=\"na\">handleSubmit<\/span>\r\n      <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n        <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">'form-group'<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-12\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">input<\/span>\r\n            <span class=\"na\">type<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'text'<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Item name'<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'name'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">name<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-6\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">input<\/span>\r\n            <span class=\"na\">type<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'number'<\/span>\r\n            <span class=\"na\">min<\/span><span class=\"o\">:<\/span>         <span class=\"s\">\"0\"<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Volume'<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'volume'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">volume<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-6\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">input<\/span>\r\n            <span class=\"na\">type<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'number'<\/span>\r\n            <span class=\"na\">min<\/span><span class=\"o\">:<\/span>         <span class=\"s\">\"0\"<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Quantity'<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'quantity'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">quantity<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-6\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">input<\/span>\r\n            <span class=\"na\">type<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'text'<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">ref<\/span><span class=\"o\">:<\/span>         <span class=\"s\">'category'<\/span>  <span class=\"c1\"># Autocomplete\u304cDOM\u30a2\u30af\u30bb\u30b9\u306b\u4f7f\u7528<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'category'<\/span>  <span class=\"c1\"># @handleChange\u51e6\u7406\u6642\u306b\u4f7f\u7528<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Category'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">category<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-6\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">input<\/span>\r\n            <span class=\"na\">type<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'text'<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">ref<\/span><span class=\"o\">:<\/span>         <span class=\"s\">'room'<\/span>  <span class=\"c1\"># Autocomplete\u304cDOM\u30a2\u30af\u30bb\u30b9\u306b\u4f7f\u7528<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'room'<\/span>  <span class=\"c1\"># @handleChange\u51e6\u7406\u6642\u306b\u4f7f\u7528<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Room'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">room<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"form-group col-sm-6\"<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">textarea<\/span>\r\n            <span class=\"na\">rows<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'3'<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span>   <span class=\"s\">'form-control'<\/span>\r\n            <span class=\"na\">placeholder<\/span><span class=\"o\">:<\/span> <span class=\"s\">'Description'<\/span>\r\n            <span class=\"na\">name<\/span><span class=\"o\">:<\/span>        <span class=\"s\">'description(optional)'<\/span>\r\n            <span class=\"na\">value<\/span><span class=\"o\">:<\/span>       <span class=\"vi\">@<\/span><span class=\"na\">state<\/span><span class=\"p\">.<\/span><span class=\"na\">description<\/span>\r\n            <span class=\"na\">onChange<\/span><span class=\"o\">:<\/span>    <span class=\"vi\">@<\/span><span class=\"na\">handleChange<\/span>\r\n\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">'col-sm-6'<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">'form-group col-sm-8'<\/span>\r\n            <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">button<\/span>\r\n              <span class=\"na\">type<\/span><span class=\"o\">:<\/span>      <span class=\"s\">'submit'<\/span>\r\n              <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"k\">if<\/span> <span class=\"vi\">@<\/span><span class=\"na\">valid<\/span><span class=\"p\">()<\/span> <span class=\"k\">then<\/span> <span class=\"s\">'btn btn-success btn-block'<\/span> <span class=\"k\">else<\/span> <span class=\"s\">'btn btn-default btn-block'<\/span>\r\n              <span class=\"na\">disabled<\/span><span class=\"o\">:<\/span>  <span class=\"o\">not<\/span> <span class=\"vi\">@<\/span><span class=\"na\">valid<\/span><span class=\"p\">()<\/span>\r\n              <span class=\"s\">'Add item'<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">'form-group col-sm-4'<\/span>\r\n            <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">button<\/span>\r\n              <span class=\"na\">type<\/span><span class=\"o\">:<\/span>      <span class=\"s\">'submit'<\/span>\r\n              <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"btn btn-default btn-block\"<\/span>\r\n              <span class=\"na\">onClick<\/span><span class=\"o\">:<\/span> <span class=\"vi\">@<\/span><span class=\"na\">handleClear<\/span>\r\n              <span class=\"s\">'Clear'<\/span>\r\n        <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span>\r\n          <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">'form-group col-sm-6'<\/span>\r\n          <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">span<\/span>\r\n            <span class=\"na\">id<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"helpBlock\"<\/span>\r\n            <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"help-block text-center\"<\/span>\r\n            <span class=\"s\">\"Please fill in all the required fields\"<\/span>\r\n      <span class=\"nx\">R<\/span><span class=\"p\">.<\/span><span class=\"na\">div<\/span> <span class=\"na\">className<\/span><span class=\"o\">:<\/span> <span class=\"s\">\"clearfix\"<\/span>\r\n<\/code><\/pre>\n<p>3. \u4e0b\u62c9\u83dc\u5355\u7684\u6837\u5f0f\u8bbe\u8ba1<\/p>\n<p>\u6309\u7167\u4e2a\u4eba\u559c\u597d\u6765\u8fdb\u884c\u9020\u578b\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">ul<\/span><span class=\"nc\">.ui-autocomplete<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nl\">position<\/span><span class=\"p\">:<\/span> <span class=\"nb\">absolute<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">list-style<\/span><span class=\"p\">:<\/span> <span class=\"nb\">none<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">margin<\/span><span class=\"p\">:<\/span> <span class=\"m\">0<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">padding<\/span><span class=\"p\">:<\/span> <span class=\"m\">0<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">border<\/span><span class=\"p\">:<\/span> <span class=\"nb\">solid<\/span> <span class=\"m\">1px<\/span> <span class=\"mh\">#999<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">cursor<\/span><span class=\"p\">:<\/span> <span class=\"nb\">default<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nt\">li<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">background-color<\/span><span class=\"p\">:<\/span> <span class=\"mh\">#FFF<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">border-top<\/span><span class=\"p\">:<\/span> <span class=\"nb\">solid<\/span> <span class=\"m\">1px<\/span> <span class=\"mh\">#DDD<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">margin<\/span><span class=\"p\">:<\/span> <span class=\"m\">0<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nl\">padding<\/span><span class=\"p\">:<\/span> <span class=\"m\">2px<\/span> <span class=\"m\">15px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"nt\">a<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nl\">color<\/span><span class=\"p\">:<\/span> <span class=\"mh\">#000<\/span><span class=\"p\">;<\/span>\r\n      <span class=\"nl\">display<\/span><span class=\"p\">:<\/span> <span class=\"nb\">block<\/span><span class=\"p\">;<\/span>\r\n      <span class=\"nl\">padding<\/span><span class=\"p\">:<\/span> <span class=\"m\">3px<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"nt\">a<\/span><span class=\"nc\">.ui-state-hover<\/span><span class=\"o\">,<\/span> <span class=\"nt\">a<\/span><span class=\"nc\">.ui-state-active<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nl\">background-color<\/span><span class=\"p\">:<\/span> <span class=\"mh\">#FFFCB2<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>4. \u4f20\u9012\u8bed\u53e5\u5019\u9009\u6570\u636e\u5e76\u5448\u73b0\u6e32\u67d3<\/p>\n<p>\u4f7f\u7528react_rails\u7684react_component\u65b9\u6cd5\u6765\u5c55\u793a\u4ee5\u4e0b\u4f8b\u5b50\u3002<br \/>\n\u63d0\u524d\u4f20\u9012\u5019\u9009\u8bed\u53e5\u6570\u636e\u8fdb\u884c\u6e32\u67d3\u3002\u5728\u7ec4\u4ef6\u5185\u90e8\u901a\u8fc7@props\u8fdb\u884c\u8bbf\u95ee\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nt\">%h1<\/span><span class=\"nc\">.page-header<\/span> Sample template\r\n\r\n<span class=\"p\">=<\/span> <span class=\"n\">react_component<\/span> <span class=\"s1\">'RecordsApp'<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"ss\">data: <\/span><span class=\"vi\">@items<\/span><span class=\"p\">,<\/span>\r\n                   <span class=\"ss\">roomSuggestions: <\/span><span class=\"no\">Room<\/span><span class=\"p\">.<\/span><span class=\"nf\">all<\/span><span class=\"p\">.<\/span><span class=\"nf\">pluck<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"name\"<\/span><span class=\"p\">),<\/span>\r\n                   <span class=\"ss\">categorySuggestions: <\/span><span class=\"vi\">@moving<\/span><span class=\"p\">.<\/span><span class=\"nf\">moving_items<\/span><span class=\"p\">.<\/span><span class=\"nf\">pluck<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"category\"<\/span><span class=\"p\">).<\/span><span class=\"nf\">uniq!<\/span> <span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p># \u53c2\u8003\u6750\u6599<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">https:\/\/jqueryui.com\/autocomplete\/<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">https:\/\/github.com\/railscasts\/102-auto-complete-association-revised<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">http:\/\/ludovf.net\/reactbook\/blog\/reactjs-jquery-ui-autocomplete.html<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">https:\/\/facebook.github.io\/react\/docs\/more-about-refs.html<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u603b\u7ed3 React.js\u306e\u5165\u529b\u30d5\u30a9\u30fc\u30e0\u3067jQuery-ui\/Autocomplete\u3092\u5229\u7528\u3057\u3001\u5229\u7528\u8005\u306e\u6587\u5b57\u5217\u5165\u529b [&hellip;]<\/p>\n","protected":false},"author":12,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-38169","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react-js\u3001jquery-ui\u548cautocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\" \/>\n<meta property=\"og:description\" content=\"\u603b\u7ed3 React.js\u306e\u5165\u529b\u30d5\u30a9\u30fc\u30e0\u3067jQuery-ui\/Autocomplete\u3092\u5229\u7528\u3057\u3001\u5229\u7528\u8005\u306e\u6587\u5b57\u5217\u5165\u529b [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react-js\u3001jquery-ui\u548cautocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-07-20T04:35:07+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T07:04:12+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d32f237434c4406c63e18\/0-0.png\" \/>\n<meta name=\"author\" content=\"\u9038, \u79d1\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u9038, \u79d1\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/\",\"name\":\"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-07-20T04:35:07+00:00\",\"dateModified\":\"2024-04-30T07:04:12+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487\",\"name\":\"\u9038, \u79d1\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g\",\"caption\":\"\u9038, \u79d1\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keyi\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react-js\u3001jquery-ui\u548cautocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355","og_description":"\u603b\u7ed3 React.js\u306e\u5165\u529b\u30d5\u30a9\u30fc\u30e0\u3067jQuery-ui\/Autocomplete\u3092\u5229\u7528\u3057\u3001\u5229\u7528\u8005\u306e\u6587\u5b57\u5217\u5165\u529b [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react-js\u3001jquery-ui\u548cautocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-07-20T04:35:07+00:00","article_modified_time":"2024-04-30T07:04:12+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d32f237434c4406c63e18\/0-0.png"}],"author":"\u9038, \u79d1","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u9038, \u79d1","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"3 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/","name":"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-07-20T04:35:07+00:00","dateModified":"2024-04-30T07:04:12+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528React.js\u3001jQuery-ui\u548cAutocomplete\u5b9e\u73b0\u5019\u9009\u8bcd\u4e0b\u62c9\u83dc\u5355"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487","name":"\u9038, \u79d1","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g","caption":"\u9038, \u79d1"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keyi\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react-js%e3%80%81jquery-ui%e5%92%8cautocomplete%e5%ae%9e%e7%8e%b0%e5%80%99%e9%80%89%e8%af%8d%e4%b8%8b%e6%8b%89%e8%8f%9c%e5%8d%95%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38169","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/12"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=38169"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38169\/revisions"}],"predecessor-version":[{"id":92623,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/38169\/revisions\/92623"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=38169"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=38169"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=38169"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}