layui--select使用以及下拉框实现键盘选择的例子


Posted in Javascript onSeptember 24, 2019

注意几点:

1.select下拉框一定要放到layui-form类下。这个layui-form不是必须放在form上,放在一个div也是可以的

2.要注意每次form render之后呢,要重新注册事件。

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
 <title>开始使用layui</title>
 <link rel="stylesheet" href="./layui/css/layui.css" rel="external nofollow" >
</head>
<body>
 
 
 
 
 
<form class="layui-form" action="">
 <div class="layui-form-item">
 <label class="layui-form-label">输入框</label>
 <div class="layui-input-block">
  <input type="text" name="title" required lay-verify="required" placeholder="请输入标题" autocomplete="off" class="layui-input">
 </div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">密码框</label>
 <div class="layui-input-inline">
  <input type="password" name="password" required lay-verify="required" placeholder="请输入密码" autocomplete="off" class="layui-input">
 </div>
 <div class="layui-form-mid layui-word-aux">辅助文字</div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">选择框</label>
 <div class="layui-input-block">
  <select name="city" lay-verify="required" lay-search>
  <option value=""></option>
  <option value="0">北京</option>
  <option value="1">上海</option>
  <option value="2">广州</option>
  <option value="3">深圳</option>
  <option value="4">杭州</option>
  </select>
 </div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">复选框</label>
 <div class="layui-input-block">
  <input type="checkbox" name="like[write]" title="写作">
  <input type="checkbox" name="like[read]" title="阅读" checked>
  <input type="checkbox" name="like[dai]" title="发呆">
 </div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">开关</label>
 <div class="layui-input-block">
  <input type="checkbox" name="switch" lay-skin="switch">
 </div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">单选框</label>
 <div class="layui-input-block">
  <input type="radio" name="sex" value="男" title="男">
  <input type="radio" name="sex" value="女" title="女" checked>
 </div>
 </div>
 <div class="layui-form-item layui-form-text">
 <label class="layui-form-label">文本域</label>
 <div class="layui-input-block">
  <textarea name="desc" placeholder="请输入内容" class="layui-textarea"></textarea>
 </div>
 </div>
 <div class="layui-form-item">
 <div class="layui-input-block">
  <button class="layui-btn" lay-submit lay-filter="formDemo">立即提交</button>
  <button type="reset" class="layui-btn layui-btn-primary">重置</button>
 </div>
 </div>
</form>
 
 
 
<script src="./layui/layui.js"></script>
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
 
 
<script type="text/javascript">
/***********layui下拉框选择,支持键盘*************/
 
layui.use('form', function(){
 var form = layui.form;
 var $ = layui.$;
 form.render();
 //每次渲染之后手注册事件
 $("dl").prev().find("input").attr("onkeydown","listenSelect.up(event,this)");
});
 
var listenSelect = {
 style:"layui-this",
 up:function (event,thisinput) {
  var keyCode = event.keyCode;
  var dl = $(thisinput).parent().next(); //找到渲染后的dl
  var curDd =(dl).find('.layui-this');
  if(keyCode==40){ //按下下键
   $(thisinput).parents('.layui-form-select').addClass('layui-form-selected');
   curDd = $(dl).find('.layui-this').nextAll(':not(.layui-hide)');
   if(curDd.length == 0){
    // curDd = $(dl).find('dd:first');
    curDd = $(dl).find('dd').not(".layui-hide").first();
   }else{
    curDd = curDd[0];
   }
  }else if(keyCode==38){
   $(thisinput).parents('.layui-form-select').addClass('layui-form-selected');
   curDd = $(dl).find('.layui-this').prevAll(':not(.layui-hide)');
   if(curDd.length == 0){
    curDd = $(dl).find('dd').not(".layui-hide").last();
   }else{
    curDd = curDd[0];
   }
  }
 
 
  dl.find("dd").removeClass(this.style); //移除样式
  $(curDd).addClass(this.style);
 
  var dd = $(dl).find('.layui-this');
 
 
  // 计算高度--start
  try{
   dd.offset().top - dl.offset().top + dl.scrollTop();
   dl.scrollTop(
    dd.offset().top - dl.offset().top + dl.scrollTop()-100
   );
  }catch(err){
   //console.log(err.stack);
  }
  // 计算高度--end
 
  if(keyCode == 13){
   $(dd).click();
   $(thisinput).focus(); // 再次得到焦点
   $(thisinput).attr("onkeydown","listenSelect.up(event,this)")
  }
  return false;
 }
};
 
/********END*******/
 
</script>
</body>
</html>

以上这篇layui--select使用以及下拉框实现键盘选择的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
对JavaScript的eval()中使用函数的进一步讨论
Jul 26 Javascript
Microsoft Ajax Minifier 压缩javascript的方法
Mar 05 Javascript
JSONP 跨域访问代理API-yahooapis实现代码
Dec 02 Javascript
使用jQuery避免鼠标双击的解决方案
Aug 21 Javascript
js实现文本框选中的方法
May 26 Javascript
JavaScript直播评论发弹幕切图功能点集合效果代码
Jun 26 Javascript
vue-cli如何快速构建vue项目
Apr 26 Javascript
利用jsonp解决js读取本地json跨域的问题
Dec 11 Javascript
js实现贪吃蛇小游戏
Oct 29 Javascript
jquery插件实现轮播图效果
Oct 19 jQuery
JavaScript使用setTimeout实现倒计时效果
Feb 19 Javascript
关于vue-router-link选择样式设置
Apr 30 Vue.js
JS防抖和节流实例解析
Sep 24 #Javascript
vue.js实现图书管理功能
Sep 24 #Javascript
layui table单元格事件修改值的方法
Sep 24 #Javascript
Javascript Dom元素获取和添加详解
Sep 24 #Javascript
微信小程序全局变量的设置、使用、修改过程解析
Sep 24 #Javascript
layui监听select变化,以及设置radio选中的方法
Sep 24 #Javascript
layui 监听select选择 获取当前select的ID名称方法
Sep 24 #Javascript
You might like
用PHP动态创建Flash动画
2006/10/09 PHP
PHP批量删除、清除UTF-8文件BOM头的代码实例
2014/04/14 PHP
WordPress网站性能优化指南
2015/11/18 PHP
CI框架的安全性分析
2016/05/18 PHP
Laravel框架查询构造器简单示例
2019/05/08 PHP
PHP实现抽奖功能实例代码
2020/06/30 PHP
斜45度寻路实现函数
2009/08/20 Javascript
jQuery AJAX实现调用页面后台方法和web服务定义的方法分享
2012/03/01 Javascript
使用原生js实现页面蒙灰(mask)效果示例代码
2014/06/20 Javascript
jquery实现多条件筛选特效代码分享
2015/08/28 Javascript
基于jQuery仿淘宝产品图片放大镜特效
2020/10/19 Javascript
javascript简单链式调用案例分析
2017/05/10 Javascript
Web技术实现移动监测的介绍
2017/09/18 Javascript
详解如何在React组件“外”使用父组件的Props
2018/01/12 Javascript
vue iview实现动态新增和删除
2020/06/17 Javascript
微信小程序地图实现展示线路
2020/07/29 Javascript
vue中touch和click共存的解决方式
2020/07/28 Javascript
Python发送Email方法实例
2014/08/21 Python
简单实现python收发邮件功能
2018/01/05 Python
python用户管理系统
2018/03/13 Python
python爬虫实例详解
2018/06/19 Python
Python将多个list合并为1个list的方法
2018/06/27 Python
python多线程实现TCP服务端
2019/09/03 Python
如何为Python终端提供持久性历史记录
2019/09/03 Python
Python异常处理机制结构实例解析
2020/07/23 Python
Python getattr()函数使用方法代码实例
2020/08/10 Python
GUESS西班牙官方网上商城:美国服饰品牌
2017/03/15 全球购物
总裁办公室主任职责
2014/01/02 职场文书
社区安全检查制度
2014/02/03 职场文书
《蒲公英》教学反思
2014/02/28 职场文书
政风行风建设责任书
2014/07/23 职场文书
改进作风怎么办发言材料
2014/08/17 职场文书
财务整改报告范文
2014/11/05 职场文书
给女朋友道歉的话大全
2015/01/20 职场文书
2015年护士长个人工作总结
2015/04/24 职场文书
pycharm无法安装cv2模块问题
2022/05/20 Python