效  果:

因为需要做一个搜索出现下拉然后点击 自动填装input 内容的 东西。

一开始使用lay-search 的控件去弄。 但是无法控制里面的内容。所以用了一些笨方法去弄

废话不说了,

html部分:


<div  >
                    <input type="text" name="HandoverCompany" id="HandoverCompany" onchange="checkInputValueLow(this)" class="layui-input" placeholder="请输入检查单位" style="position:absolute;z-index:2;width: 78%;border-right: 0px;" lay-verify="required" value="" onkeyup="search()" autocomplete="off">
                    <select type="text" id="hc_select" lay-filter="hc_select" autocomplete="off" placeholder="移交单位全称" lay-verify="required" class="layui-select" lay-search>
                        
                    </select>
                </div>


css部分:


.border-left-st{
border-left:1px solid red;
}
.border-top-st{
border-top:1px solid red;
}
.border-bottom-st{
border-bottom:1px solid red;
}

.borderRed{
border:1px solid red;
}


js+layui部分:


layui.use(['form', 'layedit', 'laydate'], function(){

var form = layui.form
      ,layer = layui.layer
      ,layedit = layui.layedit
      ,laydate = layui.laydate;
      
   
    
      form.on('select(hc_select)', function (data) {   //选择移交单位 赋值给input框
          console.log(data);
            console.log(optionValue[data.value].regAddress);
          $("#HandoverCompany").val(optionValue[data.value].enterpriseName);
          $("#enterpriseAddress").val(optionValue[data.value].regAddress);
          $("#enterpriseId").val(optionValue[data.value].enterpriseId);
          
          $("#hc_select").next().find("dl").css({ "display": "none" });
          form.render();
      });
        
      window.search = function () {
          var value = $("#HandoverCompany").val();
          $("#hc_select").val(value);
          console.log(value)
          form.render();
          
          $("#hc_select").next().find("dl").css({ "display": "block" });
          var dl = $("#hc_select").next().find("dl").children();
          var j = -1;
          for (var i = 0; i < dl.length; i++) {
              if (dl[i].innerHTML.indexOf(value) <= -1) {
                  dl[i].style.display = "none";
                  j++;
              }
              if (j == dl.length-1) {
                  $("#hc_select").next().find("dl").css({ "display": "none" });
              }
          }
          
      }
   //一定要用延迟  不然会选取不到内容
      $("#HandoverCompany").blur(function(){
          setTimeout(
              function(){$("#hc_select").next().find("dl").css({ "display": "none" });},100
              )
        });
      $("#HandoverCompany").focus(function(){
          $("#hc_select").next().find("dl").css({ "display": "block" });
        });

});

控制显示等部分


function addProblemCol(){
      $("#problemTable").append('<tr><td onclick="cutProblemCol(this)" class="cutPotiner">移除问题</td><td><input type="text" name="problemInfo" id="problemInfo"  lay-verify="problemInfo" autocomplete="off" placeholder="请输入问题详情" class="layui-input addProblemCount" maxlength="60" ></td</tr>')
  }
  function cutProblemCol(obj){
       $(obj).parent().remove();
  }
  function checkInputValue(obj){
        if($(obj).val()!='')
        {
            $(obj).removeClass("borderRed");
        }
    }
  function checkInputValueLow(obj){
       $(obj).removeClass("border-left-st");
       $(obj).removeClass("border-bottom-st");
       $(obj).removeClass("border-top-st");
       $("input").each(function(index,element){
            
           if(index ==1)
           {
               //$(element).attr("border","none");
           }
       })
  }

$("#HandoverCompany").on('compositionstart',function(){
    keyFlag = false;
})
$('#HandoverCompany').on('compositionend',function(){
    keyFlag = true;
})

判断输入状态调取后台部分


var optionValue = [];
  $("#HandoverCompany").on('input',function(){
              var value = $("#HandoverCompany").val();
              console.log("123123123");
              if(value.length>2 && keyFlag )
                 {
                  console.log(value.length)
                  console.log(keyFlag)
                  $.ajax({
                      type:"post",
                      url:"写入自己后台的地址",
                       cache:false,
                      async:true,
                      data:{你的参数},
                      success:function(data){
                               $("#hc_select").empty();
                              optionValue=[];
                               $(data).each(function(index,element){
                                  optionValue.push(element);
                               $("#hc_select").append('<option value='+index+'>'+element.enterpriseName+'</option>');
                               });
                          }
                      });
                 }
          });

提交判断看情况。 因为这里是使用的parent.xxx.open,弹窗在最上层 , 常规判断 不变就是提示的部分改了


if($(enterpriseName).val()==null || $(enterpriseName).val().trim()=='')
                   {
                    parent.layer.msg("请输入被检查单位名称");
                    //非主流写法  不可再用...  需要确定input的位置不会变  
                    $(inputTag).each(function(index,element){
                        if(index == 0)
                           {
                            $(element).addClass("border-left-st");
                            $(element).addClass("border-top-st");
                            $(element).addClass("border-bottom-st");
              
                            
                           }
                        if(index==1)
                           {
                            $(element).addClass("borderRed");
                           }
                    });
                    return  false;
                   }


使用jquery+layui 做一个输入搜索下拉 类似lay-search的更多相关文章

  1. layui-table-column-select(layui数据表格可搜索下拉框select)

    layuiTableColumnSelect 在layui table的基础上对表格列进行扩展:点击单元格显示可搜索下拉列表. 码云地址:https://gitee.com/yangqianlong9 ...

  2. jquery+php实现用户输入搜索内容时自动提示

    index.html <html> <head>     <meta charset=;} #search_auto li a:hover{background:#D8D ...

  3. 利用jquery+iframe做一个ajax上传效果

    以下是自学it网--中级班上课笔记 网址:www.zixue.it html页面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict ...

  4. jQuery实现一个淡入淡出下拉菜单 非常简易

    前段时间我一直在向大家推荐CSS3和HTML5的东西,尽管看上去很炫,但也有不少网友抱怨兼容性问题,所以今天开始我也会陆续向大家介绍一些兼容性较好的jQuery插件.今天先分享一款利用jQuery实现 ...

  5. Ajax跨域实现淘宝/百度搜索下拉提示效果

    最近学到Ajax,觉得自己对与前后端的数据交互有了一个基本的了解.下面是Ajax应用到淘宝/百度的搜索功能的一个简单的小实例,就是输入一个词,下拉框中自动显示匹配的内容:

  6. ComboBox可搜索下拉框的使用注意事项,简单记录以及我遇到的一些奇怪的bug

    前几天做一个react的项目的时候需要用一个可搜索的下拉框ComboBox,上代码: <ComboBox // className={comboxClassName} items={storeA ...

  7. 第二百二十七节,jQuery EasyUI,ComboTree(树型下拉框)组件

    jQuery EasyUI,ComboTree(树型下拉框)组件 学习要点: 1.加载方式 2.属性列表 3.方法列表 本节课重点了解EasyUI中ComboTree(树型下拉框)组件的使用方法,这个 ...

  8. 第二百二十四节,jQuery EasyUI,ComboGrid(数据表格下拉框)组件

    jQuery EasyUI,ComboGrid(数据表格下拉框)组件 学习要点: 1.加载方式 2.属性列表 3.方法列表 本节课重点了解 EasyUI 中 ComboGrid(数据表格下拉框)组件的 ...

  9. 雷林鹏分享:jQuery EasyUI 表单 - 创建树形下拉框

    jQuery EasyUI 表单 - 创建树形下拉框 树形下拉框(ComboTree)是一个带有下列树形结构(Tree)的下拉框(ComboBox).它可以作为一个表单字段进行使用,可以提交给远程服务 ...

  10. Jquery ajax 绑定multiselect多选下拉选项,同时异步执行返回值

    Jquery ajax 绑定multiselect多选下拉选项,同时异步执行获取返回值 function load(mslt_employees,belongto,mark) {//传入$(#ID) ...

随机推荐

  1. 我的vim配置相关

    谨以此文记录下之前的折腾.(后续可能还会折腾什么) 目标 我的目的很简单,就是希望能有一个启动快速的文本编辑器,可以简单的代码着色,vim键位,简单的文本修改,打开大点的文件不发愁,可以简单的form ...

  2. HJ92 在字符串中找出连续最长的数字串

    描述 输入一个字符串,返回其最长的数字子串,以及其长度.若有多个最长的数字子串,则将它们全部输出(按原字符串的相对位置) 本题含有多组样例输入. 输入描述: 输入一个字符串. 输出描述: 输出字符串中 ...

  3. [转载]Zookeeper全解析——Paxos作为灵魂

    Paxos描述了这样一个场景,有一个叫做Paxos的小岛(Island)上面住了一批居民,岛上面所有的事情由一些特殊的人决定,他们叫做议员(Senator).议员的总数(Senator Count)是 ...

  4. VUE使用axios数据请求时报错 TypeError: Cannot set property 'xxxx' of undefined 的解决办法

    正常定义全局变量: data:function (){ return{ currentOrders:[] } }, 使用Axios发送请求并获取后端数据时,如果在then中使用this.current ...

  5. docker脚本自动化安装

    1.编译构建镜像编写一个.sh的脚本,用于在linux中构建已发布项目的镜像,构建成功之后再导出镜像------该镜像是docker-compose.yml中需要用到的镜像文件 功能:使用docker ...

  6. 修改python下载镜像源

    找到pip.ini(可能在"C:\Users\Administrator\AppData\Roaming\pip\pip.ini")→记事本打开→添加相应源 如果没有找到,在C:\ ...

  7. BUU刷题记录

    [GWCTF 2019]mypassword xss+csp 打开页面可以注册登录 登进去提示不是sql注入 然后提示源码 看一下 然后有段后端代码写道了注释里 <!-- if(is_array ...

  8. springboot启动日志:Multiple Spring Data modules found, entering strict repository configuration mode

    问题描述 最近启动springboot项目的时候,发现有一条日志:Multiple Spring Data modules found, entering strict repository conf ...

  9. tool script to convert back slash

    Back slash is used in windows, which makes so many headache for me. Then an idea came to my mind. It ...

  10. allure环境配置生成测试报告

    一.pycharm中安装下载allure:pip install allure-pytest.或者设置里面添加allure-pytest搜索安装 二.电脑中配置allure系统环境变量: allure ...