时间:2021-05-26
在项目中遇到这也一个问题:
有a.html和b.html。
1.a页面已经打开,b页面尚未打开,我希望在a页面设置好一些列参数,比如背景色,宽度等参数,传递给b页面,好让b页面在打开就能应用。
2.a页面已经打开,b页面无论是否打开。在a页面需要获取到b页面的一些元素甚至变量,以便于应用到a页面。
注意:不涉及跨域问题。
想了很久,终于想到了解决方案。
第一个问题,我们可以利用html页面锚点的特性,将参数通过url传递给b页面
这是a页面代码:
<button>跳转设置</button> <script> var btn = document.querySelector('button'); console.log(window); btn.addEventListener('click', function(){ window.location = 'ci.html#bgc=#369?wd=500' }) </script>由代码可以知道,点击按钮跳转页面,跳转的url后面多了一系列参数,这个并不会影响跳转的地址,当b页面打开后,可以获取location截取字符串获得变量及变量值,再进行应用。
这是b页面代码:
<div></div> <script> var div = document.querySelector('div'); var bl = window.location.hash.slice(1).split('?'); if(bl.length >= 1){ for(var i = 0; i < bl.length; i += 1){ switch (bl[i].split('=')[0]) { case 'bgc': document.body.style.background = bl[i].split('=')[1]; break; case 'wd': div.style.width = bl[i].split('=')[1] + 'px'; break; default: null; break; } } } </script>通过截取字符串取得url传递过来的变量应用。成功!
第二个问题,我想的是通过iframe来达到目的,这只是一个障眼法。
在a页面动态创建一个iframe,并设置src值为b页面,display为none。再通过iframe的contentDocument属性获取返回的iframe的文档。
在文档内获取到所需要的元素并应用。
源码:
<span>11111111111</span> <script> var fram = document.createElement('iframe'); fram.src = 'http:///kongzhi/fram2.html'; fram.style.display = 'none'; document.body.appendChild(fram); fram.onload = function(){ var doc = fram.contentDocument || fram.contentWindow.document; var p = doc.querySelector('p'); document.body.appendChild(p); } </script>以上这篇JS控制静态页面之间传递参数获取参数并应用的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
js获取url传递参数,js获取url?号后面的参数的方法:functionGetRequest(){varurl=location.search;//获取
JS函数的参数在function内可以用arguments对象来获取。参数的调用有两种方式:1、期望参数的使用。2、实际传递参数的使用。应用举例:functio
前言在开发Wpf/SL应用时,经常会遇到不同页面和窗体之间的参数传递的问题。对于这类问题,我们一般通过事件实现数据传递,也可以定义全局静态变量来进行数据共享。这
一:url带参数传递与前端语言一样,小程序页面间的传递可以通过在路由url后接参数,路由的同时会将参数一并传递到新的页面。index.wxml:title=参数
本文实例讲述了Javascript基于AJAX回调函数传递参数的方法。分享给大家供大家参考,具体如下:前面介绍了《javascript实现html页面之间参数传