JavaScript实现form提交,回车提交URL地址伪静态[原创](javascript心得)万万没想到

随心笔谈2年前发布 编辑
156 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



文本框(input element)里输入内容后,直接Enter回车键提交表单(form),是很方便的,也很人性化,便于用户使用。比如一个搜索框,希望输入完关键词之后直接按回车键立即提交表单,但如果不使用form提交,用JavaScript来实现提交动作,而且提交URL地址伪静态化,不想带问号和搜索关键词,搜索框内enter回车键自动提交,那么应该如何实现呢。笔者下面将用实际代码来展示。

下面是html中的简单form表单:

1、一个id是keywords的搜索框;

2、placeholder是文本框默认提示文字;

3、onkeydown是在该文本框中按下动作时触发事件,event.keyCode==13表示按下的是“ENTER”回车键,触发JavaScript的formsubmit函数。注意这里有return。

4、点击“搜索”按钮会触发formsubmit函数

备注:点击“搜索”按钮和搜索框内enter回车键触发的时同一个函数

<form id=”form” method=”get” action=””>
<input type=”text” id=”keywords” name=”keywords” value=”” placeholder=”请输入关键词” onkeydown=”if(event.keyCode==13){return formsubmit();}”/>
<input type=”button” value=”搜索” onClick=”formsubmit()”>
</form>

下面是JavaScript的formsubmit函数:

1、获取文本框keywords的输入值,如果为空提示“请输入查询关键词!”;如果存在keywords进行下一步

2、用keywords取得的,伪造URL伪静态链接(后端程序设计好)

3、window.location.href跳转到url页面

4、注意这里的return false,可以使得上面的form不主动提交

<script>
function formsubmit(){
var keywords=$(‘#keywords’).val();
if (keywords) {
url=’/search/’+keywords+’.html’;
window.location.href=https://www.jb51.net/article/url;
}else{
$(‘#keywords’).focus();
alert(“请输入查询关键词!”);
}
return false;
}
</script>

如果不需要提交URL伪静态,可以直接在form中action里写入url,也可以在JavaScript中改变form中action的值,进行form提交。keywords就会变成参数加到跳转链接里。

<script>
function formsubmit(){
var keywords=$(‘#keywords’).val();
if (keywords) {
url=’search.php’;
$(“#form”).attr(‘action’,url);
$(“#form”).submit();
}else{
$(‘#keywords’).focus();
alert(“请输入查询关键词!”);
}
return false;
}
</script>

总结:上面的例子介绍了form使用javascript提交时,点击“搜索”按钮能提交,搜索框内也能使用enter回车键提交的方法和代码。详细解释了原理和各个代码的含义,简单易懂,便于学习。

到此这篇关于JavaScript实现form提交,回车提交URL地址伪静态的文章就介绍到这了,更多相关js实现form提交URL地址伪静态内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:Form表单按回车自动提交表单的实现方法Vue动态生成表格的行和列如何防止INPUT按回车自动提交表单FORMJSP中的FORM表单中只有一个input文本时,按回车键将会自动提交表单js实现键盘Enter键提交表单的方法

© 版权声明

相关文章