【转】H5 input search 提交事件

欲实现一个文字搜索的功能,要求输入时,键盘回车按钮提示显示为“搜索”。效果如下:

开始~

input type=text并不能达到这种效果,google了一下,HTML5 增加的type=search可以做到(但需要input type=search外面包上一层带action属性的form)。

        <div class="search-input-wrap clearfix">
            <div class="form-input-wrap f-l">
                <form id="searchForm" action="" class="input-kw-form">
                    <input type="searchInput" autocomplete="off" name="baike-search" placeholder="请输入关键词" class="input-kw">
                </form>
                <i class="iconfont if-message"></i>
                <i class="iconfont if-close"></i>
            </div>
            <i class="search-cancel f-l">取消</i>
        </div>

但type=search会有许多默认样式和行为,这次开发遇到的有:

  • 会默认下拉框显示搜索历史记录;
  • 输入时自动弹出“x”,“x”的样式在不同手机上,样式不同;
  • iOS 手机(测试时为iphone6 ios10)上输入框为椭圆形.

但我们希望样式按照我们自定义的样式显示,并且各个手机上能统一。

于是几经google,得到答案:

  • 设置input autocomplete="off"去掉弹出的下拉框;
  • 将默认的“x”隐藏掉:
input[type="search"]::-webkit-search-cancel-button{
    display: none;
}
  • 针对ios 设置样式, 去除ios下input 椭圆形:
-webkit-appearance: none;

同时别忘记,如果提交搜索时想使用ajax,那么可以阻止表单的默认行为

$(‘#searchForm‘).on(‘submit‘, function(event){
    //拦截表单默认提交事件
     event.preventDefault();
    //获取input框的值,用ajax提交到后台
    var content = $(‘#searchInput‘).val();
    $.ajax()..........

});


截图参考:https://segmentfault.com/a/1190000007765742
时间: 2024-10-07 12:16:09

【转】H5 input search 提交事件的相关文章

iphone H5 input type=&quot;search&quot; 不显示搜索 解决办法

H5 input type="search" 不显示搜索 解决办法 H5 input type="search" 不显示搜索 解决方法 在IOS(ipad iPhone等)系统的浏览器里打开H5页面.如下写法: <input type="search" name="search” id="search"> 以上设备的键盘仍然显示“换行”. 解决方法如下:在input外面嵌套一层form: <form

使用ajax后提交事件后禁用按钮,事件执行完毕后,重新启用按钮

一直想做这样的效果,实现的方法虽然不是很好,但效果还是出来了 <script runat="server"> /// <summary> /// 当Button2被点击,实际是Button3触发事件,这样就可以达到提交事件时禁用被提交的按钮效果 /// </summary> protected void Button_Click(object sender, EventArgs e) { System.Threading.Thread.Sleep(5

复选框 省市区 联动(监听input的change事件)

需求:省市区三级包含复选框按钮以及文字描述.点击文字显示对应的下级地区,点击复选框选择对应的下级区域勾选. 分析:监听input的change事件当点击复选框省  选择对应的第一个市区,同时默认选中第三级区域的第一个.同理监听span或者label(因为label与input的搭配使用) 辅助:后台提供省市区的数据: 两种方式: A:后台直接给dom结构(后台写好基本构架,前段自己在后台code填写需要的dom,class,方便前端开发) B:后台直接给前段一个json数据,前段自己遍历.(和后

关于解决JQUERY对INPUT元素Change事件不兼容的问题

最近开发一个项目,需要实现用户在WEB表单里的多个INPUT框中输入数量后,立即自动计算加总各项输入的数量之和,并显示在指定的INPUT框中,这个功能实现的原理是简单的,就是只需要在INPUT的onchange事件中计算加总并将结果赋给指定的INPUT框中即可实现,代码如下: $("input.syxcost").change(function(){ computeReceivedsyxcost(); } function computeReceivedsyxcost(){ //计算加

监听input变化的事件

可以监听input变化的事件 在需要监听input输入值改变的时候,可以通过原声DOM对象的事件oninput/onchange/onkeyup/onkeypress/onkeydown 事件来监听. 这几种事件的触发条件 事件名称 触发条件 onchange 事件会在域的内容改变时发生 oninput 事件在用户输入时触发 onkeyup 事件会在键盘按键被松开时发生 onkeypress 在按下按键时触发, 不能触发所有按键(例如:ALT, CTRL, SHIFT, ESC) onkeydo

React中,input外边如果包一个div,可以把input的onChange事件绑定到div上面,并且也生效

最近第一次开始学习封装组件,遇到几个比较神奇的问题. 首先就是如果input外边包一个div,如果把input的onChange事件绑定到div上,也会生效 <div onChange={(e)=>{console.log(e.target.value)}}> <Input/> </div> 还有,如果封装了一个组件,那么里面的最外层元素的{...this.props}需要慎用,虽然这样子做,可以把样式传过来,并且生效,但是会报错 原文地址:https://www

关于form下提交和重置input按钮默认事件问题

今天用js清空input值的时候死活不行,搞了半天终于可以了..原因是因为默认事件.. HTML代码 <form> <input id="input" type="txt" value="查询"> <input id="submit" type="submit" value="提交"> <input id="reset" ty

h5 新增的invalid事件,貌似有很大bug

<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8"> <title></title> <style> form{ width: 640px; margin:0 auto; } input{ display: block; width: 100%; height: 25px; margin-bottom:20px; }

【原】相煎何太急——input的blur事件与button的click事件

先来一段引子,最近在写手机h5页面,主要是一些登陆注册方面的,最绕不开的就是表单元素. 我想实现的是:在输入框后边有一个删除图标,当输入东西的时候触发事件,显示删除图标,点击该图标会删除之前输入的内容,离开输入框,该图标消失. <div class="wrapper"> <div class="count"> <label for="person">手机号</label> <input id=