首页 >> js开发 >> jsvue打开其他项目页面并传入数据详解js大全
jsvue打开其他项目页面并传入数据详解js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
1.不跨域,携带sessionstorage打开
1.不跨域,携带sessionstorage打开
主页面,存储sessionstorage后,打开页面
let data = {
text:'我是数据'
};
let isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)?true:false;
sessionStorage.setItem('information',JSON.stringify(data));
//ios不能打开新窗口,所以改为移动端在原本页面打开,pc打开新窗口
window.open(window.location.protocol + "//" + window.location.host + reportUrl, isMobile?'_self':'_blank');
let data = {
text:'我是数据'
};
let isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)?true:false;
sessionStorage.setItem('information',JSON.stringify(data));
//ios不能打开新窗口,所以改为移动端在原本页面打开,pc打开新窗口
window.open(window.location.protocol + "//" + window.location.host + reportUrl, isMobile?'_self':'_blank');
子页面
var date = JSON.parse(sessionStorage.getItem('information'));
var date = JSON.parse(sessionStorage.getItem('information'));
2.跨域,iframe通信2.跨域,iframe通信跨域的情况下,无法携带sessionstorage,通过iframe的postMessage通信机制传递数据;不跨域也可以用,但更建议使用第一种,比较丝滑~主页面,写入url,加载完成后,发送数据
let data = {
text:'我是数据'
};
this.src = url
this.$nextTick(()=>{
document.getElementById('iframe').onload=()=>{
document.getElementById('iframe').contentWindow.postMessage({
type:'preview',
data:data
},this.src)
document.getElementById('iframe').onload=null;
}
})
let data = {
text:'我是数据'
};
this.src = url
this.$nextTick(()=>{
document.getElementById('iframe').onload=()=>{
document.getElementById('iframe').contentWindow.postMessage({
type:'preview',
data:data
},this.src)
document.getElementById('iframe').onload=null;
}
})
子页面,执行监听,created、mounted都可以
created() {
window.addEventListener('message',(event)=>{
console.log(event.data.type)
if(event.data&&event.data.type=='preview'){
console.log(event.data.data)
let data = event.data.data
}
}, false);
}
created() {
window.addEventListener('message',(event)=>{
console.log(event.data.type)
if(event.data&&event.data.type=='preview'){
console.log(event.data.data)
let data = event.data.data
}
}, false);
}
总结总结
1.不跨域,携带sessionstorage打开
主页面,存储sessionstorage后,打开页面
let data = {
text:'我是数据'
};
let isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)?true:false;
sessionStorage.setItem('information',JSON.stringify(data));
//ios不能打开新窗口,所以改为移动端在原本页面打开,pc打开新窗口
window.open(window.location.protocol + "//" + window.location.host + reportUrl, isMobile?'_self':'_blank');
let data = {
text:'我是数据'
};
let isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)?true:false;
sessionStorage.setItem('information',JSON.stringify(data));
//ios不能打开新窗口,所以改为移动端在原本页面打开,pc打开新窗口
window.open(window.location.protocol + "//" + window.location.host + reportUrl, isMobile?'_self':'_blank');
子页面
var date = JSON.parse(sessionStorage.getItem('information'));
var date = JSON.parse(sessionStorage.getItem('information'));
2.跨域,iframe通信2.跨域,iframe通信跨域的情况下,无法携带sessionstorage,通过iframe的postMessage通信机制传递数据;不跨域也可以用,但更建议使用第一种,比较丝滑~主页面,写入url,加载完成后,发送数据
let data = {
text:'我是数据'
};
this.src = url
this.$nextTick(()=>{
document.getElementById('iframe').onload=()=>{
document.getElementById('iframe').contentWindow.postMessage({
type:'preview',
data:data
},this.src)
document.getElementById('iframe').onload=null;
}
})
let data = {
text:'我是数据'
};
this.src = url
this.$nextTick(()=>{
document.getElementById('iframe').onload=()=>{
document.getElementById('iframe').contentWindow.postMessage({
type:'preview',
data:data
},this.src)
document.getElementById('iframe').onload=null;
}
})
子页面,执行监听,created、mounted都可以
created() {
window.addEventListener('message',(event)=>{
console.log(event.data.type)
if(event.data&&event.data.type=='preview'){
console.log(event.data.data)
let data = event.data.data
}
}, false);
}
created() {
window.addEventListener('message',(event)=>{
console.log(event.data.type)
if(event.data&&event.data.type=='preview'){
console.log(event.data.data)
let data = event.data.data
}
}, false);
}
总结总结