我们有时候希望回车键敲在文本框(
input element
)里来提交表单(
form
),但有时候又不希望如此。比如搜索行为,希望输入完关键词之后直接按回车键立即提交表单,而有些复杂表单,可能要避免回车键误操作在未完成表单填写的时候就触发了表单提交。
要控制这些行为,不需要借助 JS ,浏览器已经帮我们做了这些处理,这里总结几条规则:
1. 如果表单里有一个 type=”submit” 的按钮,回车键生效。
2. 如果表单里只有一个 type=”text” 的 input ,不管按钮是什么 type ,回车键生效。
3. 如果按钮不是用 input ,而是用 button ,并且没有加 type , IE 下默认为 type=button , FX 默认为 type=submit 。
4. 其他表单元素如 textarea 、 select 不影响, radio checkbox 不影响触发规则,但本身在 FX 下会响应回车键,在 IE 下不响应。
5. type=”image” 的 input ,效果等同于 type=”submit” ,不知道为什么会设计这样一种 type ,不推荐使用,应该用 CSS 添加背景图合适些。
6. 我们在处理表单的页面可以检验他是否点击了按钮来控制下面的程序。 if($_POST['submit']){ 如果点击了按钮 程序继续 }
实际应用的时候,要让表单响应回车键很容易,保证表单里有个 type=”submit” 的按钮就行。而当只有一个文本框又不希望响应回车键怎么办 呢?我的方法有点别扭,就是再写一个无意义的文本框,隐藏起来。根据第 3 条规则,我们在用 button 的时候,尽量显式声明 type 以使浏览器表现一致。
通过以上可知只要把 type="submit" 改成 type="button" 然后 js 提交, 在不要有一个 type=”text” 的 input 就行了。就不会发生回车跳转。
但实验发现, ie 和火狐不一样,火狐的 submit 按钮有掩藏的( display : block )和显现的都不行,必须全改,但 ie 只要显现的没有 submit 就行了。
要控制这些行为,不需要借助 JS ,浏览器已经帮我们做了这些处理,这里总结几条规则:
1. 如果表单里有一个 type=”submit” 的按钮,回车键生效。
2. 如果表单里只有一个 type=”text” 的 input ,不管按钮是什么 type ,回车键生效。
3. 如果按钮不是用 input ,而是用 button ,并且没有加 type , IE 下默认为 type=button , FX 默认为 type=submit 。
4. 其他表单元素如 textarea 、 select 不影响, radio checkbox 不影响触发规则,但本身在 FX 下会响应回车键,在 IE 下不响应。
5. type=”image” 的 input ,效果等同于 type=”submit” ,不知道为什么会设计这样一种 type ,不推荐使用,应该用 CSS 添加背景图合适些。
6. 我们在处理表单的页面可以检验他是否点击了按钮来控制下面的程序。 if($_POST['submit']){ 如果点击了按钮 程序继续 }
实际应用的时候,要让表单响应回车键很容易,保证表单里有个 type=”submit” 的按钮就行。而当只有一个文本框又不希望响应回车键怎么办 呢?我的方法有点别扭,就是再写一个无意义的文本框,隐藏起来。根据第 3 条规则,我们在用 button 的时候,尽量显式声明 type 以使浏览器表现一致。
通过以上可知只要把 type="submit" 改成 type="button" 然后 js 提交, 在不要有一个 type=”text” 的 input 就行了。就不会发生回车跳转。
但实验发现, ie 和火狐不一样,火狐的 submit 按钮有掩藏的( display : block )和显现的都不行,必须全改,但 ie 只要显现的没有 submit 就行了。