如何在表单中显示jQuery内容


How to display jQuery content inside form

我试图在表单中进行即时搜索,所以当我开始在"品牌"输入字段中键入时,建议的术语应该出现在下面(来自我有几个品牌名称的数据库)。这是在表单外工作,但不是在表单内。。。

这是表格:

<script id="blockOfStuff" name="blockOfStuff" language="text">
<form name="add_device" enctype="multipart/form-data" action="addproduct.php?add=1" method="POST">
<div id="field">Brand: <input type="text" name="brand"></div>
<input type="submit" value="Save">
</form>
</script>

表单在script标记中,因为我需要在单击按钮时使其可见:

即时搜索是用jQuery这样做的:

<?php
$content ='<script type="text/javascript" src="jquery-1.8.0.min.js"></script>
<link rel="stylesheet" href="service.css" type="text/css">
<script type="text/javascript">
$(function() {
        $(".search").keyup(function() {
                var searchid = $(this).val();
                var dataString = ''search=''+ searchid;
                if (searchid != '''') {
                        $.ajax({
                            type: "POST",
                            url: "searchbrand.php",
                            data: dataString,
                            cache: false,
                            success: function(html) {
                                $("#result").html(html);
                            }
                        });
                    }
                    return false;
                });
            jQuery("#result").on("click", function(e) {
                    var $clicked = $(e.target);
                    var $name = $clicked.find(''.name'').html();
                        var decoded = $("<div/>").html($name).text(); $(''#searchid'').val(decoded);
                        });
                    jQuery(document).on("click", function(e) {
                        var $clicked = $(e.target);
                        if (!$clicked.hasClass("search")) {
                            jQuery("#result").fadeOut();
                        }
                    });
                    $(''#searchid'').click(function(){
                        jQuery("#result").fadeIn();
                    });
            });

</script>
<input type="text" class="search" id="searchid" placeholder="Cauta brand" />
<div id="result"></div>
';
?>
<?php echo $content; ?> // this works outside the form but not inside...

从数据库读取是在searchbrand.php中进行的,其中的行如下所示:

echo'       <div class="show" align="left" >
                <img src="http://10i.ro/images/arrow.png" style="height:15px; float:left; margin-right:2px;" /><span class="name">'.$final_brand.'</span>
            </div>';

很抱歉我迟到太久了,我需要向你展示所有的联系方式。感谢

热搜的问题在于用户打字时可以发出多少网络请求。在这种情况下,不要试图像谷歌一样,好吧,试着变得更简单。

  1. 从服务器上获取一些最想要的结果,如果你在服务器端没有太多结果,那么一次带来所有结果。

  2. 将您以前的请求保存在客户端的1级数组中,如下所示:

["Art", "Baby", "Cat", "Doge"]

  1. 现在您已经准备好立即显示结果了,请使用客户端的Fuse Search进行搜索

更新:

好的,相反,要在<script>标记中编写需要在页面上动态显示的标记,为什么不在<body>中进行语义编写呢?

如果您将这些概念分开,而不是将标签与脚本混合,则会容易得多:)

看,从语义上讲,将html元素保留在<body>中并始终使用<script>标记来承载脚本是正确的,即使您的标记是由javascript上处理的事件或操作动态创建、更改或删除的。

只需访问您想要修改的dom对象,就可以玩得很开心了!

我希望这些小技巧能对你有所帮助。

问题似乎是包含表单的<script>标记,尽管我不明白为什么。。。我已经将script标记更改为div标记,现在一切都好了
谢谢大家!

您可以使用这个jQuery插件。https://jqueryui.com/autocomplete/

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>jQuery UI Autocomplete - Default functionality</title>
  <link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">
  <script src="//code.jquery.com/jquery-1.10.2.js"></script>
  <script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
  <link rel="stylesheet" href="/resources/demos/style.css">
  <script>
  $(function() {
    var availableTags = [
      "ActionScript",
      "AppleScript",
      "Asp",
      "BASIC",
      "C",
      "C++",
      "Clojure",
      "COBOL",
      "ColdFusion",
      "Erlang",
      "Fortran",
      "Groovy",
      "Haskell",
      "Java",
      "JavaScript",
      "Lisp",
      "Perl",
      "PHP",
      "Python",
      "Ruby",
      "Scala",
      "Scheme"
    ];
    $( "#tags" ).autocomplete({
      source: availableTags
    });
  });
  </script>
</head>
<body>
<div class="ui-widget">
  <label for="tags">Tags: </label>
  <input id="tags">
</div>

</body>
</html>