300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 详解前端在html页面之间传递参数办法

详解前端在html页面之间传递参数办法

时间:2023-01-10 08:02:39

相关推荐

详解前端在html页面之间传递参数办法

web前端|html教程

html,页面传递参数,传递参数

web前端-html教程

项目中经常会出现的一种情况,有一个列表,譬如是案例列表,点击列表中的某一项,跳转至详情页面。详情是根据所点击的某条记录生成的,因为案例和具体的详情页面,都是用户后期自行添加的,我们开始编写时,不可能穷尽。因此跳转页面时,我们需要传递一个参数过去,这样我们才能通过这个参数进行数据请求,然后根据后台返回的数据来生成页面。因此,通过a标签跳转的方式,肯定是行不通的。

我们经常写form表单,提交时,可以传递参数,如果使用表单,并将其隐藏起来,应该可以达到效果。

我聊你源码,手机用vscode,ubuntu怎么安装失败,tomcat关闭校验,sqlite语句 追加,易语言 插件,前端 web 框架有哪些,爬虫和Hadoop,php $http,SEO查询社保,网站六级菜单代码,查看网页框架源代码,discuz 模板 网站,页面评议选星星怎么写,nba球员管理系统源码,免费建站程序模版lzw

除此以外,window.location.href和window.open也可以达到效果。

工业数据 源码,去掉VScode终端的调试信息,ubuntu 按e,tomcat 手机显示网页,爬虫 处理 flash,php 微信图片防盗链,江津知名seo优化怎么样lzw

1、通过form表单传递参数

落网源码,vscode提示函数,Ubuntu容器root密码,tomcat列出目录,比sqlite更好的,php 站内信 插件,前端框架准备工作,爬虫 全网监控安装,爬虫 php,seo排名因素,政府投诉网站源代码 php,php网页代码生成app,php风水模板,点击按钮弹出一个层页面不能操作.html,宠物医院管理系统源码,淘宝客程序lzw

Document<!-- -->function foo(){ var frm = window.event.srcElement; frm.hid.value = $(frm.hid).attr("index"); return true; }

点击图片时,跳转至receive.html页面。页面的url变成:

我们想要传的字符串已经传递了过来。

然后再对当前的url进行字符串分割

window.location.href.split(“=”)[1]//得到lemon

我们拿到需要传来的参数之后,就可以根据这个进行下一步的处理了。

除了上述通过字符串分割来获取url传递的参数外,我们还可以通过正则匹配和window.location.search方法来获取。

2、通过window.location.href

譬如我们点击某个列表,需要传递一个字符串到detail.html页面,然后detail.html页面根据传来的值,通过ajax交互数据,加载页面的内容。

var index = "lemon"; var url = "receive.html?index="+index; $("#more").click(function(){ window.location.href = url; });

当前页面会被替换成recieve.html的页面,页面的url变为:

然后我们再用上面的方法提取自己需要的参数

3、通过window.location.open

如果是希望打开一个新页面,而不是改变当前的页面,那么window.location.href就不适用了,此时,我们需要借助于window.location.open()来实现

简单介绍有一下window.open()函数,window.open()有三个参数,第一个参数是要打开的页面的url,第二个参数是窗口目标,第三个参数是一个特定字符串以及一个表示新页面是否取代浏览器历史集中当前加载页面的布尔值,通过只需要传递第一个参数。第二个参数还可以是”_blank”,”_self”,”_parent”,”_top”这样的特殊窗口名称,”_blank”打开新窗口,”_self”实现的效果同window.location.href.

继续上面的例子:

var index = "lemon"; var url = "receive.html?index="+index; $("#more").click(function(){ window.open(url) });

这样在点击的时候,就会打开一个新页面,页面的url地址与上面相同。

由于浏览器的安全限制,有些浏览器在弹出窗口配置方面增加限制,大多数浏览器都内置有弹出窗口的屏蔽程序,因此,弹出窗口有可能被屏蔽,在弹出窗口被屏蔽时,需要考虑两种可能性,一种是浏览器内置的屏蔽程序阻止弹出窗口,那么 window.open()很可能返回Null,此时,只要监测这个返回的值就可以确定弹出窗口是否被屏蔽。

var newWin = window.open(url);if(newWin == null){ alert("弹窗被阻止");}

另一种是浏览器扩展或其他程序阻止的弹出窗口,那么window.open()通常会抛出一个错误,因此,要像准确的检测弹出窗口是否被屏蔽,必须在检测返回值的同时,将window.open()封装在try-catch块中,上面的例子中可以写成如下形式:

var blocked = false; try{ var index = "lemon"; var url = "receive.html?index="+index; $("#more").click(function(){ var newWin = window.open(url); if(newWin == null){blocked = true; } }); } catch(ex){ block = true; } if(blocked){ alert("弹出窗口被阻止"); }

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。